说明
在 n 行、m 列的方格矩阵中,每个方格都包含一个数字。小明可以从任意方格出发开始移动。每次移动可以移到与当前方格有一条边相邻的方格(即向上、下、左或右方向移动 1 格,且不能移出边界)。除此之外,你移动到的方格中的数字必须比当前方格中的数字更大。
请你帮助小明编程规划移动路径,使路径上经过的所有数字之和最大。
本题方格中的数据根据输入的初始数字 s 按照如下算法生成:
for i = 1, 2, ... n
for j = 1, 2, ... m
s ← (s × 345) mod 19997
矩阵第 i 行第 j 列方格中的数字为(s mod 10) + 1
输入格式
正整数 n, m (方格的大小), s (数据生成器的初始数值)。1 ≤ n,m ≤ 100,1 ≤ s ≤ 19,997。
输出格式
所有合法路径中的最大数字和。
样例
输入数据 1
4 5 97
Copy
输出数据 1
24
Copy
提示
样例1:
4 5 97
样例2:
40 50 1
样例输出
样例1:
24
样例2:
47
样例1输入4 5 97,就会产生如下图所示的矩阵,那么所有合法路径中最大数字和为:4 + 5 + 7 + 8 = 24。
9 7 10 10 8
2 9 2 5 3
2 5 5 7 7
5 8 4 8 5
请分别尝试使用深搜和广搜求解;
dfs 模板
这道题不同于 “ 小x学游泳 ” 那道题,这道题不需要回溯,直接传参即可(题目要求所走的路的最大和,走过了就不能回头了)。
#include <stdio.h>
#include <math.h>
#include <algorithm>
#include <iostream>
#include <string.h>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
using namespace std;
int n,m,ans=1,vis[105][105],sum,s;
int dx[4]= {-1,0,0,1},dy[4]= {0,-1,1,0};
int a[105][105];
void dfs(int x,int y,int temp) {
vis[x][y]=1;
temp+=a[x][y];
ans=max(ans,temp);
for(int i=0; i<4; i++) {
int tx=x+dx[i],ty=y+dy[i];
if(tx>0&&ty>0&&tx<=n&&ty<=m&&vis[tx][ty]==0&&a[tx][ty]>a[x][y]) {
dfs(tx,ty,temp);
}
}
vis[x][y]=0;
}
int main() {
scanf("%d%d%d",&n,&m,&s);
for(int i=1; i<=n; i++) {
for(int j=1; j<=m; j++) {
s=((s%19997)*345)%19997;
a[i][j]=(s%10)+1;
}
}
for(int i=1; i<=n; i++) {
for(int j=1; j<=m; j++) {
sum=0;
dfs(i,j,0);
}
}
cout<<ans<<endl;
return 0;
}