问题标题: 酷町堂:4969 英灵殿 还是不行

0
0
已解决
张恩泽
张恩泽
高级天翼
高级天翼

4969   英灵殿

经验值:800 时间限制:1000毫秒

题目描述 Description

芬里尔喵终于击败了邪恶的奥丁。他手持着昆古尼尔,在英灵殿中寻找宝物。英灵殿可以看成是一个m*n个格子组成的巨大房间。英灵殿的宝器太多了,芬里尔喵给每个格子的宝器分配了一个价值,w[i][j]。芬里尔喵最初处在巨大房间的左上角,她朝着右下角的出口寻觅。由于英灵殿的魔法力量的封印,她每次只能朝右方或者下方前进。请你帮她计算一下,最后总共最多能获得的宝器的价值是多少。

输入描述 Input Description

第一行,两个整数,m n
接下来m行,第i行有n个空格隔开的整数,第j个值表示w[i][j]

输出描述 Output Description

最多能获得的宝器的总价值

样例输入 Sample Input

5 5 1 5 4 10 15 2 32 6 8 17 15 26 3 18 34 3 6 9 12 16 1 21 10 4 16

样例输出 Sample Output

151

数据范围及提示 Data Size & Hint

m, n<=10

 

//CODE
//#pragma GCC optimize(3)
//#include <bits/stdc++.h>
#include <iostream>
#include <cstdio>
using namespace std;
int n, m, max_sum, sum;
int w[15][15];
int dir[2][2] = {{0, 1}, {1, 0}};
bool vis[15][15];
void dfs(int x, int y) {
    if (x == n && y == m) {
        max_sum = max(max_sum, sum);
        sum = 0;
        return ;
    }
    for (int i = 0; i < 2; i ++) {
        int nx = x + dir[i][0], ny = y + dir[i][1];
        if (x >= 1 && x <= n && y >= 1 && y <= m && vis[nx][ny] == false) {
            vis[nx][ny] = true;
            sum += w[nx][ny];
            dfs(nx, ny);
            vis[nx][ny] = false;
            sum -= w[nx][ny];
        }
    }
}
int main() {
//  freopen ("题目名.in", "r", stdin);
//  freopen ("题目名.out", "w", stdout);
    cin >> n >> m;
    for (int i = 1; i <= n; i ++) {
        for (int j = 1; j <= m; j ++) {
            cin >> w[i][j];
        }
    }
    dfs(1, 1);
    cout << max_sum;
//  fclose (stdin);
//  fclose (stdout);
    return 0;//好习惯!
}

 

又用dfs写了一遍,竟然还是输出32!!!

求各位dalao找错


0
0
0
0
我要回答