解题思路:

注意事项:
     这个题目每个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分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论