社区讨论

求调

灌水区参与者 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;
}
虽然说这个复杂度过不了但是数据比较弱,我这个可以骗过去
但是这个样例过不了(不懂为什么) 输入:
CPP
7
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
图:
CPP
0 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 
输出:
CPP
25
我的输出:
CPP
15

回复

0 条回复,欢迎继续交流。

正在加载回复...