解题思路:
注意事项:
这个题目每个map[i][j]遍历顺序不同会影响结果,
不要使用vis[][]来记录是否走过!
参考代码:
import java.util.ArrayList;
import java.util.Scanner;
public class Main1 {
static int max = 0;
static int[] xx = {1, 0, -1, 0};
static int[] yy = {0, 1, 0, -1};
static int n;
static int m;
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
n = scanner.nextInt();
m = scanner.nextInt();
char[][] map = new char[22][22];
String s = scanner.nextLine();
for (int i = 1; i <= n; i++) {
String str = scanner.nextLine();
for (int j = 1; j <=m; j++) {
map[i][j] = str.charAt(j-1);
}
}
// for(int i=0;i<=n+1;i++){
// for(int j=0;j<=m+1;j++){
// System.out.print(map[i][j]);
// }
// System.out.println();
// }
ArrayList<Character> table = new ArrayList<>();
table.add(map[1][1]);
dfs(table,map,1,1);
System.out.println(max);
}
public static void dfs(ArrayList<Character> list, char[][] map, int x, int y) {
max=Math.max(max,list.size());
for (int k = 0; k <= 3; k++) {
int dx = xx[k] + x;
int dy = yy[k] + y;
if ( dx>=1 && dx<=m && dy>=1 && dy<=n) {
boolean can = true;
for (int i = 0; i < list.size(); i++) {
if (map[dx][dy] == list.get(i)) {
can = false;
break;
}
}
if(can){
if(map[dx][dy]!='\0') {
list.add(map[dx][dy]);
dfs(list, map, dx, dy);
list.remove(list.size()-1);
}
}
}
}
}
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复