Cod sursa(job #969324)

Utilizator gbi250Gabriela Moldovan gbi250 Data 4 iulie 2013 03:23:16
Problema Stramosi Scor 40
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.73 kb
#include <cstdio>
#include <vector>
#include <cstring>
#define dim 250001
using namespace std;
vector <int> v[dim];
int n, m, i, p, q, x;
bool viz[dim];
int dfs(int p, int q)
{
    for(int i=0;i<v[q].size();++i)
        if(!viz[v[q][i]])
        {
            viz[v[q][i]]=1;
            if(p>=1)
                return dfs(p-1, v[q][i]);
            else return q;
        }
}
int main()
{
    freopen("stramosi.in", "r", stdin);
    freopen("stramosi.out", "w", stdout);
    scanf("%d %d", &n, &m);
    for(i=1;i<=n;i++)
    {
        scanf("%d", &x);
        v[i].push_back(x);
    }
    for(i=1;i<=m;i++)
    {
        scanf("%d %d", &q, &p);
        memset(viz, 0, sizeof(viz));
        printf("%d\n", dfs(p, q));
    }
    return 0;
}