lunedì 31 marzo 2014

[C++] Pazzo

Questa mattina è successo un fatto piuttosto insolito... L’assistente tecnico del laboratorio è uscito di senno e si è messo a cambiare gli ip dei computer in rete! Questo non sarebbe un grosso problema se non fosse per il fatto che anche l’IP del server è stato modificato... Adesso ci sono grossi problemi a capire quale degli N computer del laboratorio è il server. Fino a ieri i computer erano numerati da 0 a N-l e il computer che si trovava nella prima posizione (la posizione 0) era il server, tutti gli altri computer da 1 a N-l sono ordinati secondo la loro posizione. Fortunatamente il laboratorio possiede un file di log dove vengono salvate tutte le modifiche agli indirizzi di rete dei vari dispositivi. Allo stato attuale in questo file sono presenti M righe. Ogni riga di questo file contiene due numeri, i e j che indicano i numeri dei pc che sono stati scambiati dal tecnico. Dopo un’analisi preliminare Edoardo, l’allievo incaricato di risolvere questo pasticcio, si è accorto che in ogni scambio i pc coinvolti avevano una posizione adiacente!
Scrivere un programma che dato in input N, M e la lista degli M scambi ritorni il numero del pc con l’IP del server.

Input
Il programma deve leggere da un file di nome ‘input.txt’. Nella prima riga sono presenti due interi, N e M separati da uno spazio. Nelle successive M righe sono presenti delle coppie di interi i, j separate da spazio

Output
Il programma deve scrivere in un file di nome ‘outpu.txt’. Deve essere scritto un solo intero, il numero del PC con l’IP del server.

input.txt            output.txt
5  5                    2
0  1
3  4
0  2
4  0
2  1

Basta tenere conto, negli spostamenti, del pc a cui è assegnato l' ip del server:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#include <cstdlib>
#include <iostream>
#include <fstream>

using namespace std;

int main()
{ ifstream in("input.txt");
  ofstream out("output.txt");
  
int m,n,v1,v2,ip=0;

in>> n>>m;

int pc[m][2];

for (int i=0;i<m;i++)
   in >> pc[i][0]>>pc[i][1];

for (int i=0;i<m;i++)
    if (pc[i][0] == ip)
       ip = pc[i][1];
    else if (pc[i][1] == ip)
       ip = pc[i][0];

out<<ip;

    return 0;
}

Nessun commento:

Posta un commento

Si prega di non commentare in modo volgare e/o offensivo.