Chinaunix首页 | 论坛 | 博客
  • 博客访问: 607042
  • 博文数量: 197
  • 博客积分: 7001
  • 博客等级: 大校
  • 技术积分: 2155
  • 用 户 组: 普通用户
  • 注册时间: 2005-02-24 00:29
文章分类

全部博文(197)

文章存档

2022年(1)

2019年(2)

2015年(1)

2012年(100)

2011年(69)

2010年(14)

2007年(3)

2005年(7)

分类: C/C++

2012-05-13 23:32:52

for(long long i = 0; i < tree[x].size(); ++ i)if(tree[x][i]!=pre){
// long long k = sum+cost[x][i]*(cnt+sumk[x]-t2[x][j])+ssum[x]-t1[x][j];
// long long t = cnt+1+sumk[x]-t2[x][j++];
DFS(x,tree[x][i],sum+cost[x][i]*(cnt+sumk[x]-t2[x][j])+ssum[x]-t1[x][j],cnt+1+sumk[x]-t2[x][j++]);
}





for(long long i = 0; i < tree[x].size(); ++ i)if(tree[x][i]!=pre){
long long k = sum+cost[x][i]*(cnt+sumk[x]-t2[x][j])+ssum[x]-t1[x][j];
long long t = cnt+1+sumk[x]-t2[x][j++];
DFS(x,tree[x][i],k,t);
}

为什么结果不一样 ?大写的DFS里的k  t 
如果直接写到DFS里就出错了 








答:
try this:
for(long long i = 0; i < tree[x].size(); ++ i)if(tree[x][i]!=pre){

DFS(x,tree[x][i],sum+cost[x][i]*(cnt+sumk[x]-t2[x][j])+ssum[x]-t1[x][j],cnt+1+sumk[x]-t2[x][j]);
j++;
}
与函数参数的计算次序有关,如果先处理最后的,会影响前面的参数。
阅读(937) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~