记录编号 371554 评测结果 AAAAAAAAAA
题目名称 [IOI 1994] 数塔 最终得分 100
用户昵称 GravatarHeHe 是否通过 通过
代码语言 C++ 运行时间 0.004 s
提交时间 2017-02-16 13:10:43 内存使用 0.39 MiB
显示代码纯文本
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
//#define LOCAL
int map[81][81],ans[81][81];
int pre[81][81],road[81];
int n,tmp,num_1,num_2,maxx,w;
bool flag;
void print(int,int);
int main()
{
#ifndef LOCAL
	freopen("shuta.in","r",stdin);
	freopen("shuta.out","w",stdout);
#endif
	scanf("%d",&n);
	for(int i(1);i<=n;++i)
	{
		for(int j(1);j<=i;++j)
		{
			scanf("%d",&map[i][j]);
		}
	}
	ans[1][1]=map[1][1];
	for(int i(2);i<=n;++i)
	{
		for(int j(1);j<=i;++j)
		{
			if(ans[i-1][j-1]<ans[i-1][j])
			{
				ans[i][j]=ans[i-1][j]+map[i][j];
				pre[i][j]=j;
			}
			else
			{
				ans[i][j]=ans[i-1][j-1]+map[i][j];
				pre[i][j]=j-1;
			}
		}
	}
	for(int i(1);i<=n;++i)
	{
		if(maxx<ans[n][i])
		{
			maxx=ans[n][i];
			w=i;
		}
	}
	cout<<maxx<<'\n';
	road[n]=w;
	for(int i=n-1;i>1;--i)
	{
		road[i]=pre[i+1][road[i+1]];
	}
	cout<<map[1][1];
	for(int i=2;i<=n;++i)
	  cout<<' '<<map[i][road[i]];
}