【洛谷P1268】树的重量 具体问题具体分析
2016-09-16 17:27
127 查看
好吧,在写完poj 2745这一道题以后,我完全是把这道题想复杂了,以为和上一题一样也必须把原来的树还原回来,结果还是自己太天真,因为题目并不要求输出树的形态,所以也就没有那个必要,单纯的只是求两点之间的距离,那么只是用到了poj 2745中的一个简单思想,len=g[x][i]+g[y][i]-g[x][y]因为中间的那一段重复计算,而根本没有那么复杂,so,具体问题具体分析,无论是简单题想复杂还是复杂题想简单都是不划算的
#include<cstdio> #include<cstring> #include<iostream> using namespace std; int n,g[55][55]; int ans; int main(){ while(scanf("%d",&n)!=EOF&&n){ ans=0; memset(g,0,sizeof(g)); for(int i=1;i<n;i++){ g[0][i]=g[i][0]=1e9; for(int j=i+1;j<=n;j++){ scanf("%d",&g[i][j]); g[j][i]=g[i][j]; } } for(int i=1;i<=n;i++)g[i][0]=g[0][i]=1e9; ans+=g[1][2]; for(int i=3;i<=n;i++){ int m1=0,m2=0; for(int j=1;j<i;j++){ if(g[i][j]<g[m1][i]){ m2=m1; m1=j; }else if(g[m2][i]>g[i][j]){ m2=j; } } ans+=(g[i][m1]+g[i][m2]-g[m1][m2])/2; } printf("%d\n",ans); } return 0; }/* 5 5 9 12 8 8 11 7 5 1 4 4 15 36 60 31 55 36 0 */
相关文章推荐
- [整理]ubuntu10.10编译TQ2440的x86-qtopia-2.2.0具体问题总结及原因分析
- 系统性能优化要具体问题具体分析
- UDP主要丢包原因及具体问题分析
- UDP主要丢包原因及具体问题分析
- Java Socket第一个通讯程序的具体实现及常见问题的分析
- 数据仓库项目常见综合型问题具体分析
- UDP主要丢包原因及具体问题分析
- UDP之丢包原因及具体问题分析
- 雷观(二十五):定义和分析问题,往往比解决具体问题更重要
- UDP主要丢包原因及具体问题分析
- 具体问题具体分析
- 如何通过友盟的错误信息分析项目中问题的具体位置
- 狐狸与鸭子的问题(文章转载,具体公式的分析原创)
- ubuntu10.10编译TQ2440的x86-qtopia-2.2.0具体问题总结及原因分析
- NSTimer与RunLoop的具体问题分析
- 具体问题具体分析 之 Q&A票
- 数据库字段设置问题,具体问题具体分析
- UDP主要丢包原因及具体问题分析
- PL/SQL 基础---具体问题分析
- 算法分析最小重量机器设计问题