社区讨论
求调
灌水区参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @lxuhtkwk
- 此快照首次捕获于
- 2024/06/25 22:19 2 年前
- 此快照最后确认于
- 2024/06/26 13:15 2 年前
P1004
CPP#include <bits/stdc++.h>
using namespace std;
int n;
int a[10][10];
int ans=0;
bool vis[10][10];
int don,rit;
void solve(int x,int y,int sum){
if(x>=don&&y>=rit){
ans=max(ans,sum);
return;
}
if(x<don)solve(x+1,y,sum+a[x+1][y]*(1-vis[x+1][y]));
if(y<rit)solve(x,y+1,sum+a[x][y+1]*(1-vis[x][y+1]));
}
void dfs(int x,int y,int sum){
if(x>=don&&y>=rit){
solve(1,1,sum);
return;
}
if(x<don){
vis[x+1][y]=1;
dfs(x+1,y,sum+a[x+1][y]);
vis[x+1][y]=0;
}
if(y<rit){
vis[x][y+1]=1;
dfs(x,y+1,sum+a[x][y+1]);
vis[x][y+1]=0;
}
}
int main(){
cin >> n;
int x,y,d;
cin >> x >> y >> d;
while(x!=0){
a[x][y]=d;
cin >> x >> y >> d;
}
for(int i=1;i<=n;i++){
for(int j=n;j>=1;j--){
if(a[i][j]>0){
don=max(don,j);
break;
}
}
}
for(int i=1;i<=n;i++){
for(int j=n;j>=1;j--){
if(a[j][i]>0){
rit=max(i,rit);
break;
}
}
}
vis[1][1]=1;
dfs(1,1,a[1][1]);
cout << ans;
return 0;
}
但是这个样例过不了(不懂为什么)
输入:
CPP7
1 3 2
1 4 3
2 3 3
3 3 3
5 5 4
6 5 4
7 3 2
7 5 4
0 0 0
图:
CPP0 0 2 3 0 0 0
0 0 3 0 0 0 0
0 0 3 0 0 0 0
0 0 0 0 0 0 0
0 0 0 0 4 0 0
0 0 0 0 4 0 0
0 0 2 0 4 0 0
输出:
CPP25
我的输出:
CPP15
回复
共 0 条回复,欢迎继续交流。
正在加载回复...