首页 > 代码库 > uva 699
uva 699
我们可以把它直接考虑是个一维数组,对每个点向两边扩展,记录数据在数组中,
就是DFS
#include <stdio.h> int a[81],left,right; void sort(int num,int pos) {int x,y; if (num!=-1) {if (pos<left) left=pos; if (pos>right) right=pos; a[pos]+=num; scanf("%d",&x); sort(x,pos-1); scanf("%d",&y); sort(y,pos+1); } }; int main() {int i,n,sum=0; while (scanf("%d",&n)&&n!=-1) {for (i=0;i<81;i++) a[i]=0; ++sum; left=40; right=40; sort(n,40); printf("Case %d:\n",sum); for (i=left;i<right;i++) printf("%d ",a[i]); printf("%d\n\n",a[right]); } return 0; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。