首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在java中使用回溯解决迷宫中的Rat问题

在java中使用回溯解决迷宫中的Rat问题
EN

Stack Overflow用户
提问于 2020-06-03 18:09:26
回答 1查看 53关注 0票数 0

我已经写了java代码,但是它没有提供任何output.Could,任何人都可以帮助我使用solution.thank。我已经提供了输入和输出。

这是代码-

输入-5 4 OXOO OOOX OOXO XOOO XXOO

输出-1 0 0 0 1 1 0 0 0 1 0 0 0 1 1 1 0 0 0 1

代码语言:javascript
复制
import java.util.*;

public class ratMaze {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int N = sc.nextInt();
        int M = sc.nextInt();
        char[][] ch = new char[N][M];
        for(int i=0;i<N;i++)
        {
            for(int j=0;j<M;j++)
            {
                ch[i][j]=sc.next().charAt(0);
            }
        }
        int[][] visited = new int[N][M];
        boolean res=ratmaze(ch,0,0,visited);
        if(res)
            print(visited,N,M);
        else
            System.out.print("-1");

    }

    private static boolean ratmaze(char[][]ch,int row,int col,int[][] visited)
    {
        if(row==ch.length-1 && col==ch[0].length-1)
            return true;

        if(row==ch.length || col==ch[0].length || ch[row][col]=='X' || visited[row][col]==1)
            return false;

        visited[row][col]=1;

        //Right
        ratmaze(ch,row,col+1,visited);

        //Down
        ratmaze(ch,row+1,col,visited);

        visited[row][col]=0;

        return true;
    }

    private static void print(int[][] visited,int row,int col)
    {
        for(int i=0;i<row;i++)
        {
            for(int j=0;j<col;j++)
            {
                System.out.print(visited[row][col]+" ");
            }
            System.out.println();
        }
    }

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-03 18:29:56

你的代码有两个问题。首先是你阅读输入字符的方式。Scanner.next()返回一个完整的令牌。在此上下文中,标记是一个“词”-由空格或行的开头/结尾限制的东西。在您的示例中,输入"OXOO“是一个标记。您需要修改您的读数,使令牌在外部循环中被读取,然后在特定位置访问字符。你可以这样做:

代码语言:javascript
复制
for (int i = 0; i < N; i++) {
    String token = sc.next();
    for (int j = 0; j < M; j++) {
        ch[i][j] = token.charAt(j);
    }
}

它的“工作”方式和你做的一样,但要求每个字符用空格分隔。

修复后,您将在print()方法中获得一个ArrayIndexOutOfBoundsException。在打印数组时,您应该使用ij,而不是rowcol

这将产生一些输出。我不确定这是否是您期望的输出。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62170284

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档