UVA 10009 - All Roads Lead Where?

Problem PDF

Solution:

/******************************************************************
***   Problem       :                                           ***
***   Author        : Shipu Ahamed (Psycho Timekiller)          ***
***   E-mail        : shipuahamed01@gmail.com                   ***
***   University    : BUBT,Dept. of CSE                         ***
***   Team          : BUBT_Psycho                               ***
***   My Blog       : http://shipuahamed.blogspot.com           ***
***   Facebook      : http://www.facebook.com/DeesheharaShipu   ***
******************************************************************/

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;

#define pi 2*acos(0.0)
#define all(v) v.begin(),v.end()

//input
#define si(t) scanf("%d",&t)
#define sl(t) scanf("%lld",&t)
#define sf(t) scanf("%f",&t)
#define sd(t) scanf("%lf",&t)
#define sc(c) scanf("%c",&c)
#define sii(a,b) scanf("%d%d",&a,&b)
#define sll(a,b) scanf("%lld%lld",&a,&b)

//Output
#define P(a) printf("%d\n",a)
#define PL(a) printf("%lld\n",a)
#define PF(a) printf("%f\n",a)
#define PD(a) printf("%lf\n",a)
#define PS(a) printf("%s\n",a)
#define PSN(a) printf("%s ",a)
#define PN(a) printf("%d ",a)
#define PLN(a) printf("%lld ",a)
#define PFN(a) printf("%f ",a)
#define PDN(a) printf("%lf ",a)
#define PP(a,b) printf("%d %d\n",a,b)
#define PPN(a,b) printf("%d %d ",a,b)
#define PPL(a,b) printf("%lld %lld\n",a,b)
#define PPLN(a,b) printf("%lld %lld ",a,b)

#define CP(a) cout< vi;
typedef  vector vll;
typedef  vector vs;
typedef  set si;
typedef  set ss;
typedef  map mii;
typedef  map mll;
typedef  map msi;
typedef  map mci;

template string toString( T Number ){stringstream st;st << Number;return st.str();}
template  T SOD(T n) {__typeof(n) sum=0;for(__typeof(n) i=1;i*i<=n;i++)sum+=(n%i)?0:((i*i==n)?i:i+n/i);return sum;}

//For Define
#define forab(i,a,b) for(__typeof(b) i=(a);i<=(b);i++)
#define for0(i,n) forab(i,0,(n)-1)
#define for1(i,n) forab(i,1,n)
#define rforab(i,b,a) for(__typeof(b) i=(b);i>=(a);i--)
#define rfor0(i,n) rforab(i,(n)-1,0)
#define rfor1(i,n) rforab(i,n,1)
#define forstl(i,s) for(__typeof((s).end()) i=(s).begin(); i != (s).end(); i++)

//File input/output
#define input freopen("in.txt","r",stdin)
#define output freopen("out.txt","w",stdout)

//upper bound and lower bound
#define LB(a,value) (lower_bound(all(a),value)-a.begin())
#define UB(a,value) (upper_bound(all(a),value)-a.begin())

//Test Case & New line
#define Case(no) printf("Case %d: ",++no)
#define nl puts("")

int stringconvert(string s){int p; istringstream st(s); st>>p ; return p;}

ll pow(ll a,ll b, ll m) { ll res = 1; while(b) { if(b & 1) { res = ( (res % m) * (a % m) ) %m ; } a= ((a%m) * (a%m)) %m; b >>= 1; } return res; }
ll modInverse(ll a, ll m){return pow(a,m-2,m);}

////============ CONSTANT ===============////
#define mx7   10000007
#define mx6   1000006
#define mx5   100005
#define inf   1<<30                                           //infinity value
#define eps   1e-9
#define mx    (100010)
#define mod   1000000007
////=====================================////

vector g[1000];
int vis[1000],level[1000],par[1000];

string res="";

mci in;
mapmp;

void bfs(int s,int d)
{
//    PP(s,d);

    queueq;

    cover(vis,0);
    cover(level,0);

    q.push(s);

    vis[s]=1;
    level[s]=0;

    while(!q.empty())
    {
        int p=q.front();
        q.pop();

        int len=g[p].size();
//        printf("%d ",p);
        for0(i,len)
        {
            int node=g[p][i];
            if(vis[node]==0)
            {
                level[node]=level[p]+1;
                vis[node]=1;

                q.push(node);

//                par[node]=p;

                if(node==d)
                {
                    res+=mp[node];
                    int k=level[node];
                    k--;
                    while(k!=0)
                    {
                        int len=g[node].size();
                        for0(i,len)
                        {
                            if(k==level[g[node][i]])
                            {
                                res+=mp[g[node][i]];
                                k--;
                                node=g[node][i];
                                break;
                            }
                        }
                    }
                    res+=mp[s];
                }
            }
        }
    }
}

//void path(int child,int p)
//{
//    if(child==p)
//    {
//        res+=mp[p];
//        return;
//    }
//    path(par[child],p);
//
//    res+=mp[child];
//}

int main()
{
//    input;
//    output;
    int t,no=0;
    si(t);
    while(t--)
    {
        int n,e;
        sii(n,e);

        res="";

        int node=1;
        for0(i,n)
        {
            string a,b;
            cin>>a>>b;

            if(in[a[0]]==0)
                in[a[0]]=node++;
            if(in[b[0]]==0)
                in[b[0]]=node++;

            mp[in[a[0]]]=a[0];
            mp[in[b[0]]]=b[0];

            g[in[a[0]]].pb(in[b[0]]);
            g[in[b[0]]].pb(in[a[0]]);
        }

        while(e--)
        {
            string a,b;
            cin>>a>>b;
            res="";
//            bfs(in[a[0]]);
            bfs(in[a[0]],in[b[0]]);
//            path(in[b[0]],in[a[0]]);
            reverse(res.begin(),res.end());
            cout<
https://github.com/Shipu/OnlineJudgeProblemSolutionWithCPlusPlus/tree/master/uva/10009/10009.cpp