数独小算法,测试通过(Java)

class SudokuMatrix {

    private int[][] matrix = new int[][] {            {0, 5, 0, 6, 0, 1, 0, 0, 0},            {0, 0, 7, 0, 9, 0, 0, 2, 0},            {3, 0, 0, 0, 0, 4, 0, 0, 1},            {9, 0, 0, 0, 0, 0, 1, 3, 0},            {0, 0, 8, 0, 5, 0, 7, 0, 0},            {0, 2, 6, 0, 0, 0, 0, 0, 8},            {7, 0, 0, 9, 0, 0, 0, 0, 5},            {0, 9, 0, 0, 4, 0, 3, 0, 0},            {0, 0, 0, 2, 0, 8, 0, 1, 0},    };

    public void run(){        calc();    }

    private void calc() {

        int[] coordinate = getNextData();        int m = coordinate[0];        int n = coordinate[1];

        for (int k = 1; k <= 9; k++) {            if(checkNumber(m,n,k)) {                matrix[m][n] = k;

                //System.out.println( m + "," + n + " with " + k );

                if ( getNextData() == null ) {                    print(matrix);                }                else {                    calc();                }            }

        }

        matrix[m][n] = 0;    }

    private int[] getNextData(){

        for (int row = 0; row < 9; row++) {            for (int col = 0; col < 9; col++) {                if (matrix[row][col] == 0) {                    int[] coordinateOfEmptySquare = {row, col};                    return coordinateOfEmptySquare;                }            }        }

        return null;    }

    private boolean checkNumber(int row, int col, int n) {        for (int i = 0; i < 9; i++) {            if (matrix[row][i] == n || matrix[i][col] == n) {                return false;            }        }

        int[] leftTop = {row - (row % 3), col - (col % 3)};

        for (int r = leftTop[0]; r <= leftTop[0] + 2; r++) {            for (int c = leftTop[1]; c <= leftTop[1] + 2; c++) {                if (matrix[r][c] == n) {                    return false;                }            }        }

        return true;    }

    public void print(int[][] grid) {        for (int i = 0; i < 9; i++) {            for (int j = 0; j < 9; j++) {                System.out.print(grid[i][j] + " ");            }            System.out.println();        }        System.out.println();    }

}
时间: 2024-08-10 00:07:09

数独小算法,测试通过(Java)的相关文章

java每日小算法(27)

/* [程序27]  题目:求100之内的素数    */ package test; import java.util.Scanner; public class test { public static boolean prime(int number) { boolean flag = true; int mid = (int)Math.sqrt(number); for(int i = 2; i< mid+1; i++) { if(number % i == 0) { flag = fa

java每日小算法(4)

[程序4] 题目:将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. 程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可. (2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步. (3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步. package test; import java.util.ArrayList;

java每日小算法(10)

/*[程序10]  题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半:再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高? */ package test; public class test { public static void main(String[] args) { // TODO Auto-generated method stub double high = 100.0; double jump = 0.0; double sum = 0.0; for(

java每日小算法(3)

[程序3] 题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身.例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方. 1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位. package test; public class test { public static boolean daffodil(int num) { boolean flag

java每日小算法(6)

/*[程序6] 题目:输入两个正整数m和n,求其最大公约数和最小公倍数. 1.程序分析:利用辗除法. */ package test; public class test { //最大公约数 public static int commonisor(int n, int m) { int max = (n>=m)?n:m; int min = (n>=m)?m:n; int r = max % min; while(r != 0) { max = min; min = r; r = max %

java每日小算法(5)

/*[程序5] 题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示. 1.程序分析:(a>b)?a:b这是条件运算符的基本例子. */ package test; public class test { public static String grade(int num) { String result = (num>=90)?"A":(num>=60)?"B":&quo

java每日小算法(7)

/*[程序7] 题目:输入一行字符,分别统计出其中英文字母.空格.数字和其它字符的个数. 1.程序分析:利用while语句,条件为输入的字符不为'\n'. */ package test; import java.util.ArrayList; import java.util.List; public class test { public static List<Integer> countstr(String input) { List<Integer> result = n

java每日小算法(8)

/*[程序8] 题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字.例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制. */ package test; import java.util.Scanner; public class test { public static int sum(int number, int input) { int result = 0; int tem = number; for(int i = 0;

java每日小算法(9)

/*[程序9] 题目:一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3.编程 找出1000以内的所有完数. */ package test; import java.util.ArrayList; import java.util.List; public class test { public static boolean overnum(int number) { List<Integer> list = new ArrayList<Int