数独游戏 在9x9的方格内进行, 分为3x3的小方格,被称为“区”。
数独游戏首先从已经填入数字的格子开始。
数独游戏的目的是根据下列规则,用1至9之间的数字填满空格:
每个数字在每一行、每一列和每一区只能出现一次。
我在 Linux 服务器(请参见“在 Linux 下运行 ASP.NET 2.0”)上用 ASP.NET 2.0 实现了一个数独解算器
http://www.sudoku.name 网站上也有一个用户界面相当不错的“数独解算器” ,但是其算法太差了,运算速度比我的算法慢多了。以其网站上的“#5328”谜题(也是我的数独解算器的例题)为例,它需要大约四个小时才能给出答案,而我的解算器不到一秒钟就可以给出答案。从它的运算过程来算,估计是逐个空格进行解算。而我的算法是先找出能填入数字个数最少的空格进行解算。算法这个微小的改进,就极大地提高了计算效率。好了,废话少说,下面就是源程序:

1. sudoku.aspx:
 1数独解算器(ASP.NET 2.0)<%@ Page Language="C#" inherits="Skyiv.Ben.Web.SudokuPage" %>
 2数独解算器(ASP.NET 2.0)<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
            "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>
 3数独解算器(ASP.NET 2.0)<html xmlns="http://www.w3.org/1999/xhtml" >
 4数独解算器(ASP.NET 2.0)<head runat="server">
 5数独解算器(ASP.NET 2.0)  <title>银河 - 数独</title>
 6数独解算器(ASP.NET 2.0)</head>
 7数独解算器(ASP.NET 2.0)<body>
 8数独解算器(ASP.NET 2.0)  <form id="form1" runat="server">
 9数独解算器(ASP.NET 2.0)  <asp:Button Text="返回" OnClick="BtnUriHome_Click" runat="server" />
10数独解算器(ASP.NET 2.0)  <asp:Button Text="开始" OnClick="BtnSubmit_Click" runat="server" />
11数独解算器(ASP.NET 2.0)  <hr />
12数独解算器(ASP.NET 2.0)  <div>
13数独解算器(ASP.NET 2.0)  <href="http://www.sudoku.name/index-cn.php" target="_blank">数独游戏</a>
14数独解算器(ASP.NET 2.0)  在9x9的方格内进行, 分为3x3的小方格,被称为“区”。<br />
15数独解算器(ASP.NET 2.0)  数独游戏首先从已经填入数字的格子开始。<br />
16数独解算器(ASP.NET 2.0)  数独游戏的目的是根据下列规则,用1至9之间的数字填满空格:<br />
17数独解算器(ASP.NET 2.0)  每个数字在每一行、每一列和每一区只能出现一次。<br />
18数独解算器(ASP.NET 2.0)  </div>
19数独解算器(ASP.NET 2.0)  <div>
20数独解算器(ASP.NET 2.0)  <asp:TextBox Runat="Server" Id="tbxInput" MaxLength="512" Wrap="False"
21数独解算器(ASP.NET 2.0)    TextMode="MultiLine" Columns="15" Rows="14" />
22数独解算器(ASP.NET 2.0)  <asp:TextBox Runat="Server" Id="tbxOutput" ReadOnly="True" Wrap="False"
23数独解算器(ASP.NET 2.0)    TextMode="MultiLine" Columns="15" Rows="14" />
24数独解算器(ASP.NET 2.0)  </div>
25数独解算器(ASP.NET 2.0)  </form>
26数独解算器(ASP.NET 2.0)</body>
27数独解算器(ASP.NET 2.0)</html>
28数独解算器(ASP.NET 2.0)

2. sudoku.aspx.cs:
 1数独解算器(ASP.NET 2.0)using System;
 2数独解算器(ASP.NET 2.0)using System.IO;
 3数独解算器(ASP.NET 2.0)using System.Web.UI;
 4数独解算器(ASP.NET 2.0)using System.Web.UI.WebControls;
 5数独解算器(ASP.NET 2.0)using Skyiv.Ben.Etc;
 6数独解算器(ASP.NET 2.0)
 7数独解算器(ASP.NET 2.0)namespace Skyiv.Ben.Web
 8

3. sudoku.cs:
  1数独解算器(ASP.NET 2.0)using System;
  2数独解算器(ASP.NET 2.0)using System.IO;
  3数独解算器(ASP.NET 2.0)using System.Collections.Generic;
  4数独解算器(ASP.NET 2.0)
  5数独解算器(ASP.NET 2.0)namespace Skyiv.Ben.Etc
  6

以上代码都很简单,也不需要再另外解说了。

相关文章:

  • 2022-12-23
  • 2022-02-23
  • 2021-12-24
  • 2021-08-28
  • 2021-12-24
  • 2021-04-11
  • 2021-12-28
  • 2021-10-08
猜你喜欢
  • 2021-10-12
  • 2022-12-23
  • 2021-05-14
  • 2021-10-29
  • 2021-10-21
  • 2022-12-23
相关资源
相似解决方案