| | | | 描述 Description | | | 数字三角形必须经过某一个点,使之走的路程和最大 | | | |
| | | | 输入格式 Input Format | | | 第1行n,表示n行 <=25 第2到n+1行为每个的权值 第n+2行为两个数x,y表示必须经过的点 | | | |
| | | | 时间限制 Time Limitation | | | 各个测试点1s
| | | |
|
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int inf=1<<29;
int main()
{
int n;
int a[30][30];
while(scanf("%d",&n)==1)
{
memset(a,0,sizeof(a));
for(int i=1;i<=n;i++) for(int j=1;j<=i;j++) scanf("%d",&a[i][j]);
int x,y;scanf("%d%d",&x,&y);
for(int i=1;i<=x;i++)
{
if(i==y) continue;
a[x][i]=-inf;
}
for(int i=n-1;i>=1;i--)
{
for(int j=1;j<=i;j++)
{
a[i][j]=a[i][j]+max(a[i+1][j],a[i+1][j+1]);//?
}
}
printf("%d/n",a[1][1]);
}
return 0;
}