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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include "kollib.h"
#include "message.h"
#include <iostream>
using namespace std;

int main()
{
    int odpowiedzi[NumberOfQueries()+1];
    int czas;
    int pozycja;
    int temp;
    for (int i = 1 + MyNodeId(); i <= NumberOfQueries(); i += NumberOfNodes())
    {
        czas=0;
        pozycja=QueryFrom(i);
        if (QueryFrom(i) == QueryTo(i))
            odpowiedzi[i]=0;
        else
        {
            temp=pozycja;
            pozycja=FirstNeighbor(QueryFrom(i));
            czas++;
            while(pozycja!=QueryTo(i))
            {
                if(temp==FirstNeighbor(pozycja))
                {
                    temp=pozycja;
                    pozycja=SecondNeighbor(pozycja);
                    czas++;
                }
                else
                {
                    temp=pozycja;
                    pozycja=FirstNeighbor(pozycja);
                    czas++;
                }
            }
            if(czas>NumberOfStudents()-czas)
                odpowiedzi[i]=NumberOfStudents()-czas;
            else
                odpowiedzi[i]=czas;
        }
    }

    //for (int i = 1 + MyNodeId(); i <= NumberOfQueries(); i += NumberOfNodes())
        //cout<<odpowiedzi[i]<<endl;


    if (MyNodeId() > 0) //Wysylanie
    {
        for (int i = 1 + MyNodeId(); i <= NumberOfQueries(); i += NumberOfNodes())
            PutInt(0, odpowiedzi[i]);
            Send(0);
    }
    else
    {
        for (int instancja = 1; instancja < NumberOfNodes(); ++instancja)
        {
            Receive(instancja);
            for (int i = 1 + instancja; i <= NumberOfQueries(); i += NumberOfNodes())
            {
                odpowiedzi[i] = GetInt(instancja);
                //assert(v == i);
            }
        }
        for (int i = 1; i <= NumberOfQueries(); i++)
            cout<<odpowiedzi[i]<<endl;

    }


    return 0;
}