在此实践问题中,实例化了填充0和1的方阵。您可以翻转任意大小的矩形中的值(例如0变为1,1变为0),只要该矩形的最高角在矩阵中为[0,0]。最终目标是确定必须翻转多少次才能使矩阵的所有值均为0。
如果您想要更长的解释,请转到http://usaco.org/index.php?page=viewproblem2&cpid=689,但这是基本轮廓。
这是我的代码:
import java.io.*;
import java.util.*;
public class CowTip {
static int[][] mat;
public static void main( String[] args) throws IOException, InterruptedException{
Scanner scan = new Scanner(new File("cowtip.in"));
int n = scan.nextInt();
scan.nextLine();
mat = new int[n][n];
for (int x = 0; x < n; x++) {
String str = scan.nextLine();
for (int y = 0; y < n; y++) {
mat[x][y] = Integer.parseInt(str.substring(y,y+1));
}
}
Checker c = new Checker(n-1, n-1);
int count = 0;
while (true) {
c.check();
for (int x = 0; x <= c.row; x++) {
for (int y = 0; y <= c.col; y++) {
if (mat[x][y] == 0) {
mat[x][y] = 1;
}
else if (mat[x][y] == 1) {
mat[x][y] = 0;
}
}
}
count++;
c.check();
if (c.row == -1 && c.col == -1) {
break;
}
}
System.out.println(count);
}
static class Checker {
int row;
int col;
public Checker(int r, int c) {
row = r;
col = c;
}
public Checker check() {
Checker check = new Checker(-1, -1);
for (int x = mat.length-1; x >= 0; x--) {
for (int y = mat[x].length-1; y >= 0; y--) {
if (mat[x][y] == 1) {
check = new Checker(x, y);
break;
}
}
if (check.row != -1 && check.col != -1) {
break;
}
}
return check;
}
}
}
这是输入文件(名为cowtip.in):
3
001
111
111
我已经排除了当前的调试代码,但是问题是,row
方法中的col
和check()
值是正确的值,但是每当我调用{{我的check()
中的1}}方法中,值恢复为默认值,并且没有给出正确答案,这反过来使循环无限。
关于如何解决此问题的任何想法?
编辑:我已经弄清楚了,但是谢谢大家!实际上,它非常简单(用main
代替了c = c.ckeck()
),老实说,考虑到我花了大约两个小时来调试它,我感到非常沮丧。
答案 0 :(得分:0)
将c.check()
替换为c = c.check();