Cod sursa(job #961054)

Utilizator primulDarie Sergiu primul Data 11 iunie 2013 16:36:28
Problema Amenzi Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.96 kb
#include<fstream>
#include<vector>
using namespace std;
ifstream f("amenzi.in");
ofstream g("amenzi.out");
int x,y,i,j,k,n,m,p,s,c,d[3510][155],a[3510][155];
struct nod{int x,t;};
nod nou;
vector<nod>l[155];
int main()
{
    f>>n>>m>>k>>p;
    for(i=1;i<=m;++i)
    {
        f>>x>>y>>c;
        nou.x=x;
        nou.t=c;
        l[y].push_back(nou);
        nou.x=y;
        l[x].push_back(nou);
    }
    for(i=1;i<=k;++i)
    {
        f>>x>>y>>s;
        a[y][x]+=s;
    }
    d[0][1]=1;
    for(i=1;i<=3500;++i)
    {
        for(j=1;j<=n;++j)
        {
            d[i][j]=d[i-1][j];
            for(k=0;k<l[j].size();++k)
            if(i>=l[j][k].t&&d[i-l[j][k].t][l[j][k].x]>d[i][j])
            {
                d[i][j]=d[i-l[j][k].t][l[j][k].x];
            }
            if(d[i][j])
            d[i][j]+=a[i][j];
        }
    }
    for(i=1;i<=p;++i)
    {
        f>>x>>y;
        g<<(d[y][x]-1)<<'\n';
    }
    return 0;
}