Pagini recente » Cod sursa (job #2248010) | Cod sursa (job #1169521) | Cod sursa (job #1053839) | Cod sursa (job #2538673) | Cod sursa (job #35952)
Cod sursa(job #35952)
#include <stdio.h>
FILE *f=fopen("traseu.in","r");
FILE *g=fopen("traseu.out","w");
int n,x[61][61],max=0,vmax,tot,l,apare[61];
void ciclu(int vf,int s)
{
int i;
//v[vf]=1;
if (vf==vmax&&l>0) {tot+=s;l=0;}
else
for (i=1;i<=n;i++)
if (x[vf][i])
{
l++;ciclu(i,s+x[vf][i]);
}
}
int main()
{
int m,a,b,i,c;
fscanf(f,"%d",&n);
fscanf(f,"%d",&m);
for (i=1;i<=m;i++)
{
fscanf(f,"%d",&a);
fscanf(f,"%d",&b);
fscanf(f,"%d",&c);
x[a][b]=c;
apare[a]++;
apare[b]++;
}
for (i=1;i<=n;i++)
if (apare[i]>max) {max=apare[i];vmax=i;}
ciclu(vmax,0);
fprintf(g,"%d",tot);
fclose(f);
fclose(g);
return 0;
}