/* * Copyright © 2011 Nokia Corporation. All rights reserved. * Nokia and Nokia Connecting People are registered trademarks of Nokia Corporation. * Oracle and Java are trademarks or registered trademarks of Oracle and/or its * affiliates. Other product and company names mentioned herein may be trademarks * or trade names of their respective owners. * See LICENSE.TXT for license information. */ package com.nokia.example.sudokumaster; import java.util.Random; import java.util.Vector; public class SudokuGenerator { private static final int[][] PUZZLE_0 = { {4,0,5,0,0,0,0,3,0}, {0,0,9,7,5,0,0,0,0}, {2,1,0,9,0,0,7,4,0}, {0,8,0,5,3,0,4,2,7}, {0,0,7,0,0,0,3,0,0}, {3,4,2,0,7,8,0,9,0}, {0,5,8,0,0,7,0,1,4}, {0,0,0,0,6,1,2,0,0}, {0,2,0,0,0,0,6,0,3}}; private static final int[][] PUZZLE_1 = { {9,5,0,0,3,0,0,1,2}, {0,2,0,5,0,0,3,0,0}, {0,0,8,2,6,0,0,0,0}, {0,7,1,0,9,0,8,0,0}, {6,9,0,0,8,0,0,2,3}, {0,0,3,0,5,0,6,7,0}, {0,0,0,0,2,6,5,0,0}, {0,0,7,0,0,5,0,3,0}, {5,6,0,0,1,0,0,4,7}}; private static final int[][] PUZZLE_2 = { {0,1,9,0,0,2,8,0,3}, {8,3,0,5,0,6,0,0,1}, {0,0,4,0,3,0,0,0,6}, {0,2,0,0,0,0,5,6,4}, {1,0,0,0,0,0,0,0,7}, {7,9,6,0,0,0,0,3,0}, {4,0,0,0,8,0,6,0,0}, {5,0,0,4,0,9,0,7,8}, {9,0,1,6,0,0,3,4,0}}; public static int[][] newPuzzle() { //return testPuzzle(); return randomPuzzle(); } private static int[][] randomPuzzle() { Random r = new Random(System.currentTimeMillis()); int[][] template; switch(r.nextInt(3)) { case 0: template = PUZZLE_0; break; case 1: template = PUZZLE_1; break; default: template = PUZZLE_2; break; } Vector numbera = new Vector(9); for(int n = 1; n <= 9; n++) { numbera.addElement(new Integer(n)); } int[] p = new int[10]; p[0] = 0; for(int i = 1; i < p.length; i++) { int j = r.nextInt(numbera.size()); p[i] = ((Integer) numbera.elementAt(j)).intValue(); numbera.removeElementAt(j); } int[][] puzzle = new int[9][9]; for(int i = 0; i < 9; i++) { for(int j = 0; j < 9; j++) { puzzle[i][j] = p[template[i][j]]; } } return puzzle; } private static int[][] testPuzzle() { int[][] puzzle = new int[9][9]; for(int i = 0; i < 9; i++) { for(int j = 0; j < 9; j++) { puzzle[i][j] = 1; } } puzzle[4][4] = 0; return puzzle; } }