Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/docker/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 填写一份「;电网“;使用宽度优先填充算法;I';我卡住了_Java_Breadth First Search - Fatal编程技术网

Java 填写一份「;电网“;使用宽度优先填充算法;I';我卡住了

Java 填写一份「;电网“;使用宽度优先填充算法;I';我卡住了,java,breadth-first-search,Java,Breadth First Search,编辑:我想我可能必须在run()函数中实现BFS EDIT2:我已经将代码更新为现在的代码。我对它感到不舒服,但它似乎成功地在电源导线上添加了星号。我必须输出房屋总数以及有多少房屋没有电,但我不知道如何正确地记录这一数量 EDIT3:好的,我完全相信我的网格填充是正确的。然而,我无法跟踪没有供电的房屋数量。任何关于这方面的建议都会很好 我的想法是: 我得到了一个满是符号的hxw矩阵。其中一个是代表发电厂的字母“P”。从那个发电厂,任何大写字母都是导电的,可以在地图上传送电力。最重要的是,有3个符

编辑:我想我可能必须在run()函数中实现BFS

EDIT2:我已经将代码更新为现在的代码。我对它感到不舒服,但它似乎成功地在电源导线上添加了星号。我必须输出房屋总数以及有多少房屋没有电,但我不知道如何正确地记录这一数量

EDIT3:好的,我完全相信我的网格填充是正确的。然而,我无法跟踪没有供电的房屋数量。任何关于这方面的建议都会很好

我的想法是:

我得到了一个满是符号的hxw矩阵。其中一个是代表发电厂的字母“P”。从那个发电厂,任何大写字母都是导电的,可以在地图上传送电力。最重要的是,有3个符号代表电线也携带电力。它们是:+、-、和|

最后,还有以字母“H”表示的家庭。如果与任何其他导电符号相邻,则这些符号也是导电的。这个想法是在电网中填充一个星号“*”,如果电力可以到达的话。问题是,每个发电厂P只能提供30个家庭小时的电力。我发布的代码显然没有完成,但广度优先填充算法(bff)已经完成。我可以成功地填充P旁边的任何直接符号,但我很难想出如何用不同的符号继续跟踪P。欢迎提出任何意见

输入示例:

15 22
, , , , , , , , , , . . . , , , , , , , , ,
, , . , , , , , , H H H - - + , , , , , , ,
, , , , , , , , , H H H . . | . , , , . , ,
, , , , , , , , , H H H = , | . , , , . . .
, , , , , , , , , H H H = , | . , , , . . .
, , , . . . . . , H H H = , | , , , , . . .
. . . . . . . . , H H H = , | , , , , . . .
, , . , , = = = = = = = = , | , , , . . . .
, , X X X X , . . . . C C C C C C . . . . .
. . X P X X , . . . . C C C C C C . . . . .
. . X X X X - - - - - C C C C C C . . . . .
. ~ X X X X . . . . . . . . . . . . . . . .
~ ~ ~ ~ . . . . . . . . . . . . . . . . . .
~ ~ ~ ~ ~ . . . . . . . . . . . . . . . . ~
~ ~ ~ ~ ~ ~ . . . . . . . . . . . ~ ~ . ~ ~
示例输出:

0 of 18 homes are without power .
, , , , , , , , , , . . . , , , , , , , , ,
, , . , , , , , , * * * * * * , , , , , , ,
, , , , , , , , , * * * . . * . , , , . , ,
, , , , , , , , , * * * = , * . , , , . . .
, , , , , , , , , * * * = , * . , , , . . .
, , , . . . . . , * * * = , * , , , , . . .
. . . . . . . . , * * * = , * , , , , . . .
, , . , , = = = = = = = = , * , , , . . . .
, , * * * * , . . . . * * * * * * . . . . .
. . * * * * , . . . . * * * * * * . . . . .
. . * * * * * * * * * * * * * * * . . . . .
. ~ * * * * . . . . . . . . . . . . . . . .
~ ~ ~ ~ . . . . . . . . . . . . . . . . . .
~ ~ ~ ~ ~ . . . . . . . . . . . . . . . . ~
~ ~ ~ ~ ~ ~ . . . . . . . . . . . ~ ~ . ~ ~
迄今为止的代码:

public class PowerGrid {
    String[][] grid = new String[120][120];
    LinkedList<Pair> q = new LinkedList<Pair>();
    LinkedList<Pair> visited = new LinkedList<Pair>();
    Map<Pair, Integer> dist = new HashMap<Pair, Integer>();
    ArrayList<Pair> pwrPlants = new ArrayList<Pair>();
    String[] alphabet = {"A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L",
            "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"};  
    int row = -1;
    int col = -1;

    int homesToPwr = 0;
    int homesNotPwrd = 0;
    int totalHomes = 0;

    public static void main (String[] args) {
        PowerGrid pg = new PowerGrid();
        pg. run();

    }

    public void run() {
        Scanner sc = new Scanner(System.in);

        row = sc.nextInt();
        col = sc.nextInt();

        for (int i = 0; i < row; i++)
            for (int j = 0; j < col; j++) {
                grid[i][j] = sc.next();
        }

        for (int i = 0; i < row; i++)
            for (int j = 0; j < col; j++) {
                if (grid[i][j].equals("P")) {
                    Pair tmpPair = new Pair(i, j);
                    pwrPlants.add(tmpPair);
                }
            }

        for (Pair p : pwrPlants) {
            homesToPwr += 30;
            for (String s : alphabet) {
                if (s == "H") 
                    if (homesToPwr != 0) 
                        homesToPwr--;                       

                bff(grid, p.x, p.y, s, "*");
            }

            bff(grid, p.x, p.y, "-", "*");
            bff(grid, p.x, p.y, "+", "*");
            bff(grid, p.x, p.y, "|", "*");
        }

        System.out.println(homesToPwr + " of " + totalHomes + " are without power.");

        for (int i = 0; i < row; i++) {
            for (int j = 0; j < col; j++) {
                System.out.print(grid[i][j]);
            }
            System.out.println();
        }
    }

    public void bff (String[][] grid, int x, int y, String oldSymbol, String newSymbol) {
        if (oldSymbol == newSymbol) return;


        Pair pair = new Pair(x,y);
        q.addLast(pair);
        dist.put(pair, 0);
        grid[x][y] = newSymbol;

        while (!q.isEmpty()) {
            Pair v = q.getFirst();
            q.pop();
            int d = dist.get(v) + 1;
            String[] symbols = {"+", "-", "|"};

            visit(grid, v.x + 1, v.y, new Pair(v.x+1, v.y), oldSymbol, newSymbol, d);
            visit(grid, v.x - 1, v.y, new Pair(v.x-1, v.y), oldSymbol, newSymbol, d);
            visit(grid, v.x, v.y + 1, new Pair(v.x, v.y+1), oldSymbol, newSymbol, d);
            visit(grid, v.x, v.y - 1, new Pair(v.x, v.y-1), oldSymbol, newSymbol, d);

            for (String t : alphabet){
                if (t == "H") {
                    if (homesToPwr != 0) {
                        homesToPwr--;
                    }
                }

                    visit(grid, v.x + 1, v.y, new Pair(v.x+1, v.y), t, newSymbol, d);
                    visit(grid, v.x - 1, v.y, new Pair(v.x-1, v.y), t, newSymbol, d);
                    visit(grid, v.x, v.y + 1, new Pair(v.x, v.y+1), t, newSymbol, d);
                    visit(grid, v.x, v.y - 1, new Pair(v.x, v.y-1), t, newSymbol, d);

            }
            for (String s : symbols) {
                visit(grid, v.x + 1, v.y, new Pair(v.x+1, v.y), s, newSymbol, d);
                visit(grid, v.x - 1, v.y, new Pair(v.x-1, v.y), s, newSymbol, d);
                visit(grid, v.x, v.y + 1, new Pair(v.x, v.y+1), s, newSymbol, d);
                visit(grid, v.x, v.y - 1, new Pair(v.x, v.y-1), s, newSymbol, d);
            }
        }
    }

    public void visit (String[][] A, int x, int y, Pair pair, String oldSymbol, String newSymbol, int d) {
        if ((x >= 0 && y >= 0) && (x < row && y < col) && A[x][y].equals(oldSymbol)) {
            if (oldSymbol == "H")
                totalHomes++;
            A[x][y] = newSymbol;
            dist.put(pair, d);
            q.addLast(pair);

        }
    }

    public class Pair {
        int x, y;
        public Pair (int x, int y) {
            this.x = x;
            this.y = y;
        }

        public String toString() {
            String out = "X: " + this.x + "  Y: " + this.y;
            return out;
        }
    }
}
公共级电网{
字符串[][]网格=新字符串[120][120];
LinkedList q=新建LinkedList();
已访问LinkedList=新建LinkedList();
Map dist=new HashMap();
ArrayList pwrPlants=新的ArrayList();
字符串[]字母={“A”、“B”、“C”、“D”、“E”、“F”、“G”、“H”、“I”、“J”、“K”、“L”,
“M”、“N”、“O”、“P”、“Q”、“R”、“S”、“T”、“U”、“V”、“W”、“X”、“Y”、“Z”};
int行=-1;
int col=-1;
int homesToPwr=0;
int homesNotPwrd=0;
int-totalHomes=0;
公共静态void main(字符串[]args){
PowerGrid pg=新的PowerGrid();
pg.run();
}
公开募捐{
扫描仪sc=新的扫描仪(System.in);
行=sc.nextInt();
col=sc.nextInt();
对于(int i=0;i=0&&y>=0)和((x
您的程序没有正确计算房屋的总数量

例如,这里有19栋房子,但只有18栋是住宅
15 22
, , , , , , , , , , . . . , , , , , , , , ,
, , . , , , , H , H H H - - + , , , , , , ,
, , , , , , , , , H H H . . | . , , , . , ,
, , , , , , , , , H H H = , | . , , , . . .
, , , , , , , , , H H H = , | . , , , . . .
, , , . . . . . , H H H = , | , , , , . . .
. . . . . . . . , H H H = , | , , , , . . .
, , . , , = = = = = = = = , | , , , . . . .
, , X X X X , . . . . C C C C C C . . . . .
. . X P X X , . . . . C C C C C C . . . . .
. . X X X X - - - - - C C C C C C . . . . .
. ~ X X X X . . . . . . . . . . . . . . . .
~ ~ ~ ~ . . . . . . . . . . . . . . . . . .
~ ~ ~ ~ ~ . . . . . . . . . . . . . . . . ~
~ ~ ~ ~ ~ ~ . . . . . . . . . . . ~ ~ . ~ ~
    for (int i = 0; i < row; i++)
        for (int j = 0; j < col; j++) {
            grid[i][j] = sc.next();
            if(grid[i][j].equals("H")){
                totalHomes++;
            }
        }
public void visit (String[][] A, int x, int y, Pair pair, String oldSymbol, String newSymbol, int d) {
    if ((x >= 0 && y >= 0) && (x < row && y < col) && A[x][y].equals(oldSymbol)) {
        if (oldSymbol == "H")
            homesPwrd++;
        A[x][y] = newSymbol;
        dist.put(pair, d);
        q.addLast(pair);

    }
}
    System.out.println(totalHomes-homesPwrd + " of " + totalHomes + " are without power.");
    1 of 19 are without power.
    ,,,,,,,,,,...,,,,,,,,,
    ,,.,,,,H,******,,,,,,,
    ,,,,,,,,,***..*.,,,.,,
    ,,,,,,,,,***=,*.,,,...
    ,,,,,,,,,***=,*.,,,...
    ,,,.....,***=,*,,,,...
    ........,***=,*,,,,...
    ,,.,,========,*,,,....
    ,,****,....******.....
    ..****,....******.....
    ..***************.....
    .~****................
    ~~~~..................
    ~~~~~................~
    ~~~~~~...........~~.~~