test/gs/javatest.html

Sun, 02 Mar 2025 16:06:24 +0100

author
Mike Becker <universe@uap-core.de>
date
Sun, 02 Mar 2025 16:06:24 +0100
changeset 91
2c8514b3891b
parent 66
1b12cf799fee
permissions
-rw-r--r--

add number highlighting

fixes #393

41
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 <!DOCTYPE html>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 <html>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 <head>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 <title>c2html</title>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 <style type="text/css">
66
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
6 div.c2html-code {
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
7 white-space: pre;
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
8 font-family: monospace;
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
9 }
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
10 a.c2html-lineno {
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
11 /* as long as user-select isn't widely spread, we throw the bomb */
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
12 -webkit-user-select: none;
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
13 -moz-user-select: none;
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
14 -ms-user-select: none;
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
15 user-select: none;
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
16 display: inline-block;
41
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 font-style: italic;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 text-decoration: none;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 color: grey;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 }
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 span.c2html-keyword {
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 color: blue;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 }
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 span.c2html-macroconst {
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 color: cornflowerblue;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 }
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27 span.c2html-type {
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28 color: teal;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 }
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30 span.c2html-directive {
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
31 color: silver;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32 }
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
33 span.c2html-string {
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
34 color: darkorange;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35 }
91
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
36 span.c2html-number {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
37 color: dodgerblue;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
38 }
41
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
39 span.c2html-comment {
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
40 color: grey;
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41 }
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
42 span.c2html-stdinclude, span.c2html-userinclude, a.c2html-userinclude {
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
43 }
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
44 </style>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
45 </head>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
46 <body>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
47
66
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
48 <div class="c2html-code">
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
49 <a class="c2html-lineno" name="l1" href="#l1"> 1 </a><span class="c2html-comment">/*</span>
91
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
50 <a class="c2html-lineno" name="l2" href="#l2"> 2 </a><span class="c2html-comment"> * Copyright 2013 Mike Becker. All rights reserved.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
51 <a class="c2html-lineno" name="l3" href="#l3"> 3 </a><span class="c2html-comment"> * </span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
52 <a class="c2html-lineno" name="l4" href="#l4"> 4 </a><span class="c2html-comment"> * Redistribution and use in source and binary forms, with or without</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
53 <a class="c2html-lineno" name="l5" href="#l5"> 5 </a><span class="c2html-comment"> * modification, are permitted provided that the following conditions are met:</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
54 <a class="c2html-lineno" name="l6" href="#l6"> 6 </a><span class="c2html-comment"> * </span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
55 <a class="c2html-lineno" name="l7" href="#l7"> 7 </a><span class="c2html-comment"> * 1. Redistributions of source code must retain the above copyright</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
56 <a class="c2html-lineno" name="l8" href="#l8"> 8 </a><span class="c2html-comment"> * notice, this list of conditions and the following disclaimer.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
57 <a class="c2html-lineno" name="l9" href="#l9"> 9 </a><span class="c2html-comment"> * </span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
58 <a class="c2html-lineno" name="l10" href="#l10"> 10 </a><span class="c2html-comment"> * 2. Redistributions in binary form must reproduce the above copyright</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
59 <a class="c2html-lineno" name="l11" href="#l11"> 11 </a><span class="c2html-comment"> * notice, this list of conditions and the following disclaimer in the</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
60 <a class="c2html-lineno" name="l12" href="#l12"> 12 </a><span class="c2html-comment"> * documentation and/or other materials provided with the distribution.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
61 <a class="c2html-lineno" name="l13" href="#l13"> 13 </a><span class="c2html-comment"> * </span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
62 <a class="c2html-lineno" name="l14" href="#l14"> 14 </a><span class="c2html-comment"> * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
63 <a class="c2html-lineno" name="l15" href="#l15"> 15 </a><span class="c2html-comment"> * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
64 <a class="c2html-lineno" name="l16" href="#l16"> 16 </a><span class="c2html-comment"> * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
65 <a class="c2html-lineno" name="l17" href="#l17"> 17 </a><span class="c2html-comment"> * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
66 <a class="c2html-lineno" name="l18" href="#l18"> 18 </a><span class="c2html-comment"> * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
67 <a class="c2html-lineno" name="l19" href="#l19"> 19 </a><span class="c2html-comment"> * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
68 <a class="c2html-lineno" name="l20" href="#l20"> 20 </a><span class="c2html-comment"> * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
69 <a class="c2html-lineno" name="l21" href="#l21"> 21 </a><span class="c2html-comment"> * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
70 <a class="c2html-lineno" name="l22" href="#l22"> 22 </a><span class="c2html-comment"> * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
71 <a class="c2html-lineno" name="l23" href="#l23"> 23 </a><span class="c2html-comment"> * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
72 <a class="c2html-lineno" name="l24" href="#l24"> 24 </a><span class="c2html-comment"> * POSSIBILITY OF SUCH DAMAGE.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
73 <a class="c2html-lineno" name="l25" href="#l25"> 25 </a><span class="c2html-comment"> */</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
74 <a class="c2html-lineno" name="l26" href="#l26"> 26 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
75 <a class="c2html-lineno" name="l27" href="#l27"> 27 </a><span class="c2html-keyword">package</span> de.uapcore.sudoku;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
76 <a class="c2html-lineno" name="l28" href="#l28"> 28 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
77 <a class="c2html-lineno" name="l29" href="#l29"> 29 </a><span class="c2html-keyword">import</span> java.util.ArrayList;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
78 <a class="c2html-lineno" name="l30" href="#l30"> 30 </a><span class="c2html-keyword">import</span> java.util.List;
66
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
79 <a class="c2html-lineno" name="l31" href="#l31"> 31 </a>
91
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
80 <a class="c2html-lineno" name="l32" href="#l32"> 32 </a><span class="c2html-comment">/**</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
81 <a class="c2html-lineno" name="l33" href="#l33"> 33 </a><span class="c2html-comment"> * Implements the backtracking algorithm for solving the Sudoku.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
82 <a class="c2html-lineno" name="l34" href="#l34"> 34 </a><span class="c2html-comment"> */</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
83 <a class="c2html-lineno" name="l35" href="#l35"> 35 </a><span class="c2html-keyword">public</span> <span class="c2html-keyword">final</span> <span class="c2html-keyword">class</span> <span class="c2html-type">Solver</span> {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
84 <a class="c2html-lineno" name="l36" href="#l36"> 36 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
85 <a class="c2html-lineno" name="l37" href="#l37"> 37 </a> <span class="c2html-keyword">public</span> <span class="c2html-keyword">static</span> <span class="c2html-keyword">final</span> <span class="c2html-keyword">int</span> <span class="c2html-type">VERSION</span> = <span class="c2html-number">0x1000</span>;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
86 <a class="c2html-lineno" name="l38" href="#l38"> 38 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
87 <a class="c2html-lineno" name="l39" href="#l39"> 39 </a> <span class="c2html-keyword">private</span> <span class="c2html-type">Integer</span> fillInCandidate(<span class="c2html-type">Field</span> f, <span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidates, <span class="c2html-keyword">int</span> x, <span class="c2html-keyword">int</span> y) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
88 <a class="c2html-lineno" name="l40" href="#l40"> 40 </a> <span class="c2html-type">Integer</span> c = candidates[x][y].remove(<span class="c2html-number">0</span>);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
89 <a class="c2html-lineno" name="l41" href="#l41"> 41 </a> f.setCellValue(x, y, c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
90 <a class="c2html-lineno" name="l42" href="#l42"> 42 </a> f.setCellModified(x, y, true);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
91 <a class="c2html-lineno" name="l43" href="#l43"> 43 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> i = <span class="c2html-number">0</span> ; i &lt; <span class="c2html-number">9</span> ; i++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
92 <a class="c2html-lineno" name="l44" href="#l44"> 44 </a> candidates[x][i].remove(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
93 <a class="c2html-lineno" name="l45" href="#l45"> 45 </a> candidates[i][y].remove(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
94 <a class="c2html-lineno" name="l46" href="#l46"> 46 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
95 <a class="c2html-lineno" name="l47" href="#l47"> 47 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> i = <span class="c2html-number">0</span> ; i &lt; <span class="c2html-number">3</span> ; i++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
96 <a class="c2html-lineno" name="l48" href="#l48"> 48 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> j = <span class="c2html-number">0</span> ; j &lt; <span class="c2html-number">3</span> ; j++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
97 <a class="c2html-lineno" name="l49" href="#l49"> 49 </a> candidates[x-x%<span class="c2html-number">3</span>+i][y-y%<span class="c2html-number">3</span>+j].remove(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
98 <a class="c2html-lineno" name="l50" href="#l50"> 50 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
99 <a class="c2html-lineno" name="l51" href="#l51"> 51 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
100 <a class="c2html-lineno" name="l52" href="#l52"> 52 </a> <span class="c2html-keyword">return</span> c;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
101 <a class="c2html-lineno" name="l53" href="#l53"> 53 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
102 <a class="c2html-lineno" name="l54" href="#l54"> 54 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
103 <a class="c2html-lineno" name="l55" href="#l55"> 55 </a> <span class="c2html-keyword">private</span> <span class="c2html-keyword">void</span> makeBackup(<span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidates, <span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidatesBackup) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
104 <a class="c2html-lineno" name="l56" href="#l56"> 56 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">9</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
105 <a class="c2html-lineno" name="l57" href="#l57"> 57 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">9</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
106 <a class="c2html-lineno" name="l58" href="#l58"> 58 </a> candidatesBackup[x][y] = <span class="c2html-keyword">new</span> <span class="c2html-type">ArrayList</span>&lt;&gt;(<span class="c2html-number">9</span>);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
107 <a class="c2html-lineno" name="l59" href="#l59"> 59 </a> candidatesBackup[x][y].addAll(candidates[x][y]);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
108 <a class="c2html-lineno" name="l60" href="#l60"> 60 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
109 <a class="c2html-lineno" name="l61" href="#l61"> 61 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
110 <a class="c2html-lineno" name="l62" href="#l62"> 62 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
111 <a class="c2html-lineno" name="l63" href="#l63"> 63 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
112 <a class="c2html-lineno" name="l64" href="#l64"> 64 </a> <span class="c2html-keyword">private</span> <span class="c2html-keyword">void</span> makeBackup(<span class="c2html-type">Field</span> f, <span class="c2html-keyword">int</span>[][] fieldBackup) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
113 <a class="c2html-lineno" name="l65" href="#l65"> 65 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">9</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
114 <a class="c2html-lineno" name="l66" href="#l66"> 66 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">9</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
115 <a class="c2html-lineno" name="l67" href="#l67"> 67 </a> fieldBackup[x][y] = f.getCellValue(x, y);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
116 <a class="c2html-lineno" name="l68" href="#l68"> 68 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
117 <a class="c2html-lineno" name="l69" href="#l69"> 69 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
118 <a class="c2html-lineno" name="l70" href="#l70"> 70 </a> }
66
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
119 <a class="c2html-lineno" name="l71" href="#l71"> 71 </a>
91
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
120 <a class="c2html-lineno" name="l72" href="#l72"> 72 </a> <span class="c2html-keyword">private</span> <span class="c2html-keyword">void</span> restoreBackup(<span class="c2html-type">Field</span> f, <span class="c2html-keyword">int</span>[][] fieldBackup) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
121 <a class="c2html-lineno" name="l73" href="#l73"> 73 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">9</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
122 <a class="c2html-lineno" name="l74" href="#l74"> 74 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">9</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
123 <a class="c2html-lineno" name="l75" href="#l75"> 75 </a> f.setCellValue(x, y, fieldBackup[x][y]);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
124 <a class="c2html-lineno" name="l76" href="#l76"> 76 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
125 <a class="c2html-lineno" name="l77" href="#l77"> 77 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
126 <a class="c2html-lineno" name="l78" href="#l78"> 78 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
127 <a class="c2html-lineno" name="l79" href="#l79"> 79 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
128 <a class="c2html-lineno" name="l80" href="#l80"> 80 </a> <span class="c2html-keyword">private</span> <span class="c2html-keyword">void</span> restoreBackup(<span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidates, <span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidatesBackup) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
129 <a class="c2html-lineno" name="l81" href="#l81"> 81 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">9</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
130 <a class="c2html-lineno" name="l82" href="#l82"> 82 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">9</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
131 <a class="c2html-lineno" name="l83" href="#l83"> 83 </a> candidates[x][y].clear();
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
132 <a class="c2html-lineno" name="l84" href="#l84"> 84 </a> candidates[x][y].addAll(candidatesBackup[x][y]);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
133 <a class="c2html-lineno" name="l85" href="#l85"> 85 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
134 <a class="c2html-lineno" name="l86" href="#l86"> 86 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
135 <a class="c2html-lineno" name="l87" href="#l87"> 87 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
136 <a class="c2html-lineno" name="l88" href="#l88"> 88 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
137 <a class="c2html-lineno" name="l89" href="#l89"> 89 </a> <span class="c2html-keyword">private</span> <span class="c2html-keyword">boolean</span> solve(<span class="c2html-type">Field</span> f, <span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidates) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
138 <a class="c2html-lineno" name="l90" href="#l90"> 90 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
139 <a class="c2html-lineno" name="l91" href="#l91"> 91 </a> <span class="c2html-comment">// Make backup</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
140 <a class="c2html-lineno" name="l92" href="#l92"> 92 </a> <span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidatesBackup = <span class="c2html-keyword">new</span> <span class="c2html-type">List</span>[<span class="c2html-number">9</span>][<span class="c2html-number">9</span>];
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
141 <a class="c2html-lineno" name="l93" href="#l93"> 93 </a> <span class="c2html-keyword">int</span>[][] fieldBackup = <span class="c2html-keyword">new</span> <span class="c2html-keyword">int</span>[<span class="c2html-number">9</span>][<span class="c2html-number">9</span>];
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
142 <a class="c2html-lineno" name="l94" href="#l94"> 94 </a> makeBackup(candidates, candidatesBackup);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
143 <a class="c2html-lineno" name="l95" href="#l95"> 95 </a> makeBackup(f, fieldBackup);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
144 <a class="c2html-lineno" name="l96" href="#l96"> 96 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
145 <a class="c2html-lineno" name="l97" href="#l97"> 97 </a> <span class="c2html-comment">// Fill in distinct solutions</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
146 <a class="c2html-lineno" name="l98" href="#l98"> 98 </a> <span class="c2html-keyword">boolean</span> fillDistinct;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
147 <a class="c2html-lineno" name="l99" href="#l99"> 99 </a> <span class="c2html-keyword">do</span> {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
148 <a class="c2html-lineno" name="l100" href="#l100">100 </a> fillDistinct = false;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
149 <a class="c2html-lineno" name="l101" href="#l101">101 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">9</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
150 <a class="c2html-lineno" name="l102" href="#l102">102 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">9</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
151 <a class="c2html-lineno" name="l103" href="#l103">103 </a> <span class="c2html-keyword">if</span> (f.isCellEmpty(x, y) &amp;&amp; candidates[x][y].size() == <span class="c2html-number">1</span>) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
152 <a class="c2html-lineno" name="l104" href="#l104">104 </a> fillInCandidate(f, candidates, x, y);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
153 <a class="c2html-lineno" name="l105" href="#l105">105 </a> fillDistinct = true;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
154 <a class="c2html-lineno" name="l106" href="#l106">106 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
155 <a class="c2html-lineno" name="l107" href="#l107">107 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
156 <a class="c2html-lineno" name="l108" href="#l108">108 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
157 <a class="c2html-lineno" name="l109" href="#l109">109 </a> } <span class="c2html-keyword">while</span> (fillDistinct);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
158 <a class="c2html-lineno" name="l110" href="#l110">110 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
159 <a class="c2html-lineno" name="l111" href="#l111">111 </a> <span class="c2html-comment">// Try out remaining candidates</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
160 <a class="c2html-lineno" name="l112" href="#l112">112 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">9</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
161 <a class="c2html-lineno" name="l113" href="#l113">113 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">9</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
162 <a class="c2html-lineno" name="l114" href="#l114">114 </a> <span class="c2html-keyword">if</span> (f.isCellEmpty(x, y)) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
163 <a class="c2html-lineno" name="l115" href="#l115">115 </a> <span class="c2html-keyword">while</span> (candidates[x][y].size() &gt; <span class="c2html-number">0</span>) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
164 <a class="c2html-lineno" name="l116" href="#l116">116 </a> <span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] cb = <span class="c2html-keyword">new</span> <span class="c2html-type">List</span>[<span class="c2html-number">9</span>][<span class="c2html-number">9</span>];
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
165 <a class="c2html-lineno" name="l117" href="#l117">117 </a> makeBackup(candidates, cb);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
166 <a class="c2html-lineno" name="l118" href="#l118">118 </a> <span class="c2html-type">Integer</span> c = fillInCandidate(f, candidates, x, y);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
167 <a class="c2html-lineno" name="l119" href="#l119">119 </a> <span class="c2html-keyword">if</span> (solve(f, candidates)) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
168 <a class="c2html-lineno" name="l120" href="#l120">120 </a> <span class="c2html-keyword">break</span>;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
169 <a class="c2html-lineno" name="l121" href="#l121">121 </a> } <span class="c2html-keyword">else</span> {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
170 <a class="c2html-lineno" name="l122" href="#l122">122 </a> f.clearCellValue(x, y);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
171 <a class="c2html-lineno" name="l123" href="#l123">123 </a> restoreBackup(candidates, cb);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
172 <a class="c2html-lineno" name="l124" href="#l124">124 </a> <span class="c2html-comment">// Remove current candidate anyway</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
173 <a class="c2html-lineno" name="l125" href="#l125">125 </a> candidates[x][y].remove(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
174 <a class="c2html-lineno" name="l126" href="#l126">126 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
175 <a class="c2html-lineno" name="l127" href="#l127">127 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
176 <a class="c2html-lineno" name="l128" href="#l128">128 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
177 <a class="c2html-lineno" name="l129" href="#l129">129 </a> <span class="c2html-keyword">if</span> (f.isCellEmpty(x, y)) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
178 <a class="c2html-lineno" name="l130" href="#l130">130 </a> restoreBackup(f, fieldBackup);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
179 <a class="c2html-lineno" name="l131" href="#l131">131 </a> restoreBackup(candidates, candidatesBackup);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
180 <a class="c2html-lineno" name="l132" href="#l132">132 </a> <span class="c2html-keyword">return</span> false;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
181 <a class="c2html-lineno" name="l133" href="#l133">133 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
182 <a class="c2html-lineno" name="l134" href="#l134">134 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
183 <a class="c2html-lineno" name="l135" href="#l135">135 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
184 <a class="c2html-lineno" name="l136" href="#l136">136 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
185 <a class="c2html-lineno" name="l137" href="#l137">137 </a> <span class="c2html-keyword">return</span> true;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
186 <a class="c2html-lineno" name="l138" href="#l138">138 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
187 <a class="c2html-lineno" name="l139" href="#l139">139 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
188 <a class="c2html-lineno" name="l140" href="#l140">140 </a> <span class="c2html-comment">/**</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
189 <a class="c2html-lineno" name="l141" href="#l141">141 </a><span class="c2html-comment"> * Attempts to solve the given Sudoku field.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
190 <a class="c2html-lineno" name="l142" href="#l142">142 </a><span class="c2html-comment"> *</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
191 <a class="c2html-lineno" name="l143" href="#l143">143 </a><span class="c2html-comment"> * The solution, if any, is directly entered into the field.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
192 <a class="c2html-lineno" name="l144" href="#l144">144 </a><span class="c2html-comment"> * All solved fields will be in modified state.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
193 <a class="c2html-lineno" name="l145" href="#l145">145 </a><span class="c2html-comment"> * The already given fields are left untouched.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
194 <a class="c2html-lineno" name="l146" href="#l146">146 </a><span class="c2html-comment"> *</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
195 <a class="c2html-lineno" name="l147" href="#l147">147 </a><span class="c2html-comment"> * @param f the field to solve</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
196 <a class="c2html-lineno" name="l148" href="#l148">148 </a><span class="c2html-comment"> * @return true if a solution could be found, false if the field is unsolvable</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
197 <a class="c2html-lineno" name="l149" href="#l149">149 </a><span class="c2html-comment"> */</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
198 <a class="c2html-lineno" name="l150" href="#l150">150 </a> <span class="c2html-keyword">public</span> <span class="c2html-keyword">boolean</span> solve(<span class="c2html-type">Field</span> f) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
199 <a class="c2html-lineno" name="l151" href="#l151">151 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
200 <a class="c2html-lineno" name="l152" href="#l152">152 </a> <span class="c2html-comment">// Calculate initial candidates</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
201 <a class="c2html-lineno" name="l153" href="#l153">153 </a> <span class="c2html-type">List</span>&lt;<span class="c2html-type">Integer</span>&gt;[][] candidates = <span class="c2html-keyword">new</span> <span class="c2html-type">List</span>[<span class="c2html-number">9</span>][<span class="c2html-number">9</span>];
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
202 <a class="c2html-lineno" name="l154" href="#l154">154 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">9</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
203 <a class="c2html-lineno" name="l155" href="#l155">155 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">9</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
204 <a class="c2html-lineno" name="l156" href="#l156">156 </a> candidates[x][y] = <span class="c2html-keyword">new</span> <span class="c2html-type">ArrayList</span>&lt;&gt;(<span class="c2html-number">9</span>);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
205 <a class="c2html-lineno" name="l157" href="#l157">157 </a> <span class="c2html-keyword">if</span> (f.getCellValue(x, y) == <span class="c2html-number">0</span>) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
206 <a class="c2html-lineno" name="l158" href="#l158">158 </a> <span class="c2html-comment">// All numbers are candidates</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
207 <a class="c2html-lineno" name="l159" href="#l159">159 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> c = <span class="c2html-number">1</span> ; c &lt;= <span class="c2html-number">9</span> ; c++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
208 <a class="c2html-lineno" name="l160" href="#l160">160 </a> candidates[x][y].add(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
209 <a class="c2html-lineno" name="l161" href="#l161">161 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
210 <a class="c2html-lineno" name="l162" href="#l162">162 </a> <span class="c2html-comment">// Remove row duplicates</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
211 <a class="c2html-lineno" name="l163" href="#l163">163 </a> <span class="c2html-keyword">int</span>[] line = f.getRow(y);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
212 <a class="c2html-lineno" name="l164" href="#l164">164 </a> <span class="c2html-keyword">for</span> (<span class="c2html-type">Integer</span> c : line) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
213 <a class="c2html-lineno" name="l165" href="#l165">165 </a> candidates[x][y].remove(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
214 <a class="c2html-lineno" name="l166" href="#l166">166 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
215 <a class="c2html-lineno" name="l167" href="#l167">167 </a> <span class="c2html-comment">// Remove column duplicates</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
216 <a class="c2html-lineno" name="l168" href="#l168">168 </a> line = f.getColumn(x);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
217 <a class="c2html-lineno" name="l169" href="#l169">169 </a> <span class="c2html-keyword">for</span> (<span class="c2html-type">Integer</span> c : line) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
218 <a class="c2html-lineno" name="l170" href="#l170">170 </a> candidates[x][y].remove(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
219 <a class="c2html-lineno" name="l171" href="#l171">171 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
220 <a class="c2html-lineno" name="l172" href="#l172">172 </a> <span class="c2html-comment">// Remove square duplicates</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
221 <a class="c2html-lineno" name="l173" href="#l173">173 </a> <span class="c2html-keyword">int</span>[][] square = f.getSquare(x/<span class="c2html-number">3</span>, y/<span class="c2html-number">3</span>);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
222 <a class="c2html-lineno" name="l174" href="#l174">174 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span>[] sq : square) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
223 <a class="c2html-lineno" name="l175" href="#l175">175 </a> <span class="c2html-keyword">for</span> (<span class="c2html-type">Integer</span> c : sq) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
224 <a class="c2html-lineno" name="l176" href="#l176">176 </a> candidates[x][y].remove(c);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
225 <a class="c2html-lineno" name="l177" href="#l177">177 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
226 <a class="c2html-lineno" name="l178" href="#l178">178 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
227 <a class="c2html-lineno" name="l179" href="#l179">179 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
228 <a class="c2html-lineno" name="l180" href="#l180">180 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
229 <a class="c2html-lineno" name="l181" href="#l181">181 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
230 <a class="c2html-lineno" name="l182" href="#l182">182 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
231 <a class="c2html-lineno" name="l183" href="#l183">183 </a> <span class="c2html-comment">// Backtrack</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
232 <a class="c2html-lineno" name="l184" href="#l184">184 </a> <span class="c2html-keyword">return</span> solve(f, candidates);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
233 <a class="c2html-lineno" name="l185" href="#l185">185 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
234 <a class="c2html-lineno" name="l186" href="#l186">186 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
235 <a class="c2html-lineno" name="l187" href="#l187">187 </a> <span class="c2html-comment">/**</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
236 <a class="c2html-lineno" name="l188" href="#l188">188 </a><span class="c2html-comment"> * Performs a fast check whether any field violates the Sudoku rules.</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
237 <a class="c2html-lineno" name="l189" href="#l189">189 </a><span class="c2html-comment"> *</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
238 <a class="c2html-lineno" name="l190" href="#l190">190 </a><span class="c2html-comment"> * @param f the field to check</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
239 <a class="c2html-lineno" name="l191" href="#l191">191 </a><span class="c2html-comment"> * @return true, if the check succeeds, false otherwise</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
240 <a class="c2html-lineno" name="l192" href="#l192">192 </a><span class="c2html-comment"> */</span>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
241 <a class="c2html-lineno" name="l193" href="#l193">193 </a> <span class="c2html-keyword">public</span> <span class="c2html-keyword">boolean</span> check(<span class="c2html-type">Field</span> f) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
242 <a class="c2html-lineno" name="l194" href="#l194">194 </a> <span class="c2html-keyword">int</span>[] line;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
243 <a class="c2html-lineno" name="l195" href="#l195">195 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> i = <span class="c2html-number">0</span> ; i &lt; <span class="c2html-number">9</span> ; i++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
244 <a class="c2html-lineno" name="l196" href="#l196">196 </a> line = f.getRow(i);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
245 <a class="c2html-lineno" name="l197" href="#l197">197 </a> <span class="c2html-keyword">if</span> (!valid(line)) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
246 <a class="c2html-lineno" name="l198" href="#l198">198 </a> <span class="c2html-keyword">return</span> false;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
247 <a class="c2html-lineno" name="l199" href="#l199">199 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
248 <a class="c2html-lineno" name="l200" href="#l200">200 </a> line = f.getColumn(i);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
249 <a class="c2html-lineno" name="l201" href="#l201">201 </a> <span class="c2html-keyword">if</span> (!valid(line)) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
250 <a class="c2html-lineno" name="l202" href="#l202">202 </a> <span class="c2html-keyword">return</span> false;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
251 <a class="c2html-lineno" name="l203" href="#l203">203 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
252 <a class="c2html-lineno" name="l204" href="#l204">204 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
253 <a class="c2html-lineno" name="l205" href="#l205">205 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
254 <a class="c2html-lineno" name="l206" href="#l206">206 </a> <span class="c2html-keyword">int</span>[][] square;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
255 <a class="c2html-lineno" name="l207" href="#l207">207 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">3</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
256 <a class="c2html-lineno" name="l208" href="#l208">208 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> y = <span class="c2html-number">0</span> ; y &lt; <span class="c2html-number">3</span> ; y++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
257 <a class="c2html-lineno" name="l209" href="#l209">209 </a> square = f.getSquare(x, y);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
258 <a class="c2html-lineno" name="l210" href="#l210">210 </a> <span class="c2html-keyword">if</span> (!valid(square)) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
259 <a class="c2html-lineno" name="l211" href="#l211">211 </a> <span class="c2html-keyword">return</span> false;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
260 <a class="c2html-lineno" name="l212" href="#l212">212 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
261 <a class="c2html-lineno" name="l213" href="#l213">213 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
262 <a class="c2html-lineno" name="l214" href="#l214">214 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
263 <a class="c2html-lineno" name="l215" href="#l215">215 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
264 <a class="c2html-lineno" name="l216" href="#l216">216 </a> <span class="c2html-keyword">return</span> true;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
265 <a class="c2html-lineno" name="l217" href="#l217">217 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
266 <a class="c2html-lineno" name="l218" href="#l218">218 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
267 <a class="c2html-lineno" name="l219" href="#l219">219 </a> <span class="c2html-keyword">private</span> <span class="c2html-keyword">boolean</span> valid(<span class="c2html-keyword">int</span>[] line) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
268 <a class="c2html-lineno" name="l220" href="#l220">220 </a> <span class="c2html-keyword">int</span>[] numbers;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
269 <a class="c2html-lineno" name="l221" href="#l221">221 </a> numbers = <span class="c2html-keyword">new</span> <span class="c2html-keyword">int</span>[<span class="c2html-number">9</span>];
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
270 <a class="c2html-lineno" name="l222" href="#l222">222 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> i = <span class="c2html-number">0</span> ; i &lt; <span class="c2html-number">9</span> ; i++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
271 <a class="c2html-lineno" name="l223" href="#l223">223 </a> <span class="c2html-keyword">int</span> l = line[i]<span class="c2html-number">-1</span>;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
272 <a class="c2html-lineno" name="l224" href="#l224">224 </a> <span class="c2html-keyword">if</span> (l &gt;= <span class="c2html-number">0</span>) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
273 <a class="c2html-lineno" name="l225" href="#l225">225 </a> <span class="c2html-keyword">if</span> ((++numbers[l]) &gt; <span class="c2html-number">1</span>) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
274 <a class="c2html-lineno" name="l226" href="#l226">226 </a> <span class="c2html-keyword">return</span> false;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
275 <a class="c2html-lineno" name="l227" href="#l227">227 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
276 <a class="c2html-lineno" name="l228" href="#l228">228 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
277 <a class="c2html-lineno" name="l229" href="#l229">229 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
278 <a class="c2html-lineno" name="l230" href="#l230">230 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
279 <a class="c2html-lineno" name="l231" href="#l231">231 </a> <span class="c2html-keyword">return</span> true;
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
280 <a class="c2html-lineno" name="l232" href="#l232">232 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
281 <a class="c2html-lineno" name="l233" href="#l233">233 </a>
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
282 <a class="c2html-lineno" name="l234" href="#l234">234 </a> <span class="c2html-keyword">private</span> <span class="c2html-keyword">boolean</span> valid(<span class="c2html-keyword">int</span>[][] square) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
283 <a class="c2html-lineno" name="l235" href="#l235">235 </a> <span class="c2html-keyword">int</span>[] line = <span class="c2html-keyword">new</span> <span class="c2html-keyword">int</span>[<span class="c2html-number">9</span>];
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
284 <a class="c2html-lineno" name="l236" href="#l236">236 </a> <span class="c2html-keyword">for</span> (<span class="c2html-keyword">int</span> x = <span class="c2html-number">0</span> ; x &lt; <span class="c2html-number">3</span> ; x++) {
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
285 <a class="c2html-lineno" name="l237" href="#l237">237 </a> <span class="c2html-type">System</span>.arraycopy(square[x], <span class="c2html-number">0</span>, line, <span class="c2html-number">3</span>*x, <span class="c2html-number">3</span>);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
286 <a class="c2html-lineno" name="l238" href="#l238">238 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
287 <a class="c2html-lineno" name="l239" href="#l239">239 </a> <span class="c2html-keyword">return</span> valid(line);
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
288 <a class="c2html-lineno" name="l240" href="#l240">240 </a> }
2c8514b3891b add number highlighting
Mike Becker <universe@uap-core.de>
parents: 66
diff changeset
289 <a class="c2html-lineno" name="l241" href="#l241">241 </a>}
66
1b12cf799fee upgrade to ucx 3.0
Mike Becker <universe@uap-core.de>
parents: 41
diff changeset
290 </div>
41
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
291 </body>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
292 </html>
c06ab07fd29d increases input buffer + adds regression tests
Mike Becker <universe@uap-core.de>
parents:
diff changeset
293

mercurial