导航:首页 > 编程语言 > java数独算法

java数独算法

发布时间:2024-11-15 18:43:06

❶ 给推荐三个适合女孩玩的java游戏,不要打打杀杀的,要求是像“都市摩天楼、bounce tales"

看你的游戏兴趣应该是喜欢那种休闲类游戏了,推荐几个供参考。

益智类:巫婆魔法气泡 ,大富豪物语之奶油狮童话历险 ,童话小富婆,牛人社之南瓜缆车大作战 。

养成类:猫耳娘梦工厂,时尚24小时之花样少女,狗狗口袋屋。

经营类:萌系女仆8.5度c ,田园物语,美女菠萝包,开心餐城。开心花园。牧场物语2之恋爱季节。

恋爱类:恋爱物语之湛蓝回忆 ,花样少年恋爱学院,恋色狂想-魔女恋歌,猫恋物语之约定的彼方。
换装类:名模时装周,百变甜心女孩。

❷ Java数独游戏代码

public class ShuDu {
/**存储数字的数组*/
static int[][] n = new int[9][9];
/**生成随机数字的源数组,随机数字从该数组中产生*/
static int[] num = {1,2,3,4,5,6,7,8,9};
public static void main(String[] args) {
//生成数字
for(int i = 0;i < 9;i++){
//尝试填充的数字次数
int time = 0;
//填充数字
for(int j = 0;j < 9;j++){
//产生数字
n[i][j] = generateNum(time);
//如果返回值为0,则代表卡住,退回处理
//退回处理的原则是:如果不是第一列,则先倒退到前一列,否则倒退到前一行的最后一列
if(n[i][j] == 0){
//不是第一列,则倒退一列
if(j > 0){
j-=2;
continue;
}else{//是第一列,则倒退到上一行的最后一列
i--;
j = 8;
continue;
}
}
//填充成功
if(isCorret(i,j)){
//初始化time,为下一次填充做准备
time = 0;
}else{ //继续填充
//次数增加1
time++;
//继续填充当前格
j--;
}
}
}
//输出结果
for(int i = 0;i < 9;i++){
for(int j = 0;j < 9;j++){
System.out.print(n[i][j] + " ");
}
System.out.println();
}
}

/**
* 是否满足行、列和3X3区域不重复的要求
* @param row 行号
* @param col 列号
* @return true代表符合要求
*/
public static boolean isCorret(int row,int col){
return (checkRow(row) & checkLine(col) & checkNine(row,col));
}

/**
* 检查行是否符合要求
* @param row 检查的行号
* @return true代表符合要求
*/
public static boolean checkRow(int row){
for(int j = 0;j < 8;j++){
if(n[row][j] == 0){
continue;
}
for(int k =j + 1;k< 9;k++){
if(n[row][j] == n[row][k]){
return false;
}
}
}
return true;
}

/**
* 检查列是否符合要求
* @param col 检查的列号
* @return true代表符合要求
*/
public static boolean checkLine(int col){
for(int j = 0;j < 8;j++){
if(n[j][col] == 0){
continue;
}
for(int k =j + 1;k< 9;k++){
if(n[j][col] == n[k][col]){
return false;
}
}
}
return true;
}

/**
* 检查3X3区域是否符合要求
* @param row 检查的行号
* @param col 检查的列号
* @return true代表符合要求
*/
public static boolean checkNine(int row,int col){
//获得左上角的坐标
int j = row / 3 * 3;
int k = col /3 * 3;
//循环比较
for(int i = 0;i < 8;i++){
if(n[j + i/3][k + i % 3] == 0){
continue;
}
for(int m = i+ 1;m < 9;m++){
if(n[j + i/3][k + i % 3] == n[j + m/3][k + m % 3]){
return false;
}
}
}
return true;
}

/**
* 产生1-9之间的随机数字
* 规则:生成的随机数字放置在数组8-time下标的位置,随着time的增加,已经尝试过的数字将不会在取到
* 说明:即第一次次是从所有数字中随机,第二次时从前八个数字中随机,依次类推,
* 这样既保证随机,也不会再重复取已经不符合要求的数字,提高程序的效率
* 这个规则是本算法的核心
* @param time 填充的次数,0代表第一次填充
* @return
*/
public static int generateNum(int time){
//第一次尝试时,初始化随机数字源数组
if(time == 0){
for(int i = 0;i < 9;i++){
num[i] = i + 1;
}
}
//第10次填充,表明该位置已经卡住,则返回0,由主程序处理退回
if(time == 9){
return 0;
}
//不是第一次填充
//生成随机数字,该数字是数组的下标,取数组num中该下标对应的数字为随机数字
int ranNum = (int)(Math.random() * (9 - time));
//把数字放置在数组倒数第time个位置,
int temp = num[8 - time];
num[8 - time] = num[ranNum];
num[ranNum] = temp;
//返回数字
return num[8 - time];
}
}

❸ 九游下了个数独达人 java游戏怎么玩呀游戏收费吗

九游9game。Çn里的单机游戏都是完全破解的,不收费的,下载了游戏注意看下游戏说明,把以9*9形式构成的81个填满是本游戏的目的.同时每一行,每一列和3*3小方格格内不能重复,切必须出现一次1~9数字.

❹ 用java做一个数独游戏,有现成代码,只需弄一下文字的东西就可以啦,不用太复杂,普普通通的就行.

public class ShuDu {
/**存储数字的数组*/
static int[][] n = new int[9][9];
/**生成随机数字的源数组,随机数字从该数组中产生*/
static int[] num = {1,2,3,4,5,6,7,8,9};
public static void main(String[] args) {
//生成数字
for(int i = 0;i < 9;i++){
//尝试填充的数字次数
int time = 0;
//填充数字
for(int j = 0;j < 9;j++){
//产生数字
n[i][j] = generateNum(time);
//如果返回值为0,则代表卡住,退回处理
//退回处理的原则是:如果不是第一列,则先倒退到前一列,否则倒退到前一行的最后一列
if(n[i][j] == 0){
//不是第一列,则倒退一列
if(j > 0){
j-=2;
continue;
}else{//是第一列,则倒退到上一行的最后一列
i--;
j = 8;
continue;
}
}
//填充成功
if(isCorret(i,j)){
//初始化time,为下一次填充做准备
time = 0;
}else{ //继续填充
//次数增加1
time++;
//继续填充当前格
j--;
}
}
}
//输出结果
for(int i = 0;i < 9;i++){
for(int j = 0;j < 9;j++){
System.out.print(n[i][j] + " ");
}
System.out.println();
}
}

/**
* 是否满足行、列和3X3区域不重复的要求
* @param row 行号
* @param col 列号
* @return true代表符合要求
*/
public static boolean isCorret(int row,int col){
return (checkRow(row) & checkLine(col) & checkNine(row,col));
}

/**
* 检查行是否符合要求
* @param row 检查的行号
* @return true代表符合要求
*/
public static boolean checkRow(int row){
for(int j = 0;j < 8;j++){
if(n[row][j] == 0){
continue;
}
for(int k =j + 1;k< 9;k++){
if(n[row][j] == n[row][k]){
return false;
}
}
}
return true;
}

/**
* 检查列是否符合要求
* @param col 检查的列号
* @return true代表符合要求
*/
public static boolean checkLine(int col){
for(int j = 0;j < 8;j++){
if(n[j][col] == 0){
continue;
}
for(int k =j + 1;k< 9;k++){
if(n[j][col] == n[k][col]){
return false;
}
}
}
return true;
}

/**
* 检查3X3区域是否符合要求
* @param row 检查的行号
* @param col 检查的列号
* @return true代表符合要求
*/
public static boolean checkNine(int row,int col){
//获得左上角的坐标
int j = row / 3 * 3;
int k = col /3 * 3;
//循环比较
for(int i = 0;i < 8;i++){
if(n[j + i/3][k + i % 3] == 0){
continue;
}
for(int m = i+ 1;m < 9;m++){
if(n[j + i/3][k + i % 3] == n[j + m/3][k + m % 3]){
return false;
}
}
}
return true;
}

/**
* 产生1-9之间的随机数字
* 规则:生成的随机数字放置在数组8-time下标的位置,随着time的增加,已经尝试过的数字将不会在取到
* 说明:即第一次次是从所有数字中随机,第二次时从前八个数字中随机,依次类推,
* 这样既保证随机,也不会再重复取已经不符合要求的数字,提高程序的效率
* 这个规则是本算法的核心
* @param time 填充的次数,0代表第一次填充
* @return
*/
public static int generateNum(int time){
//第一次尝试时,初始化随机数字源数组
if(time == 0){
for(int i = 0;i < 9;i++){
num[i] = i + 1;
}
}
//第10次填充,表明该位置已经卡住,则返回0,由主程序处理退回
if(time == 9){
return 0;
}
//不是第一次填充
//生成随机数字,该数字是数组的下标,取数组num中该下标对应的数字为随机数字
int ranNum = (int)(Math.random() * (9 - time));
//把数字放置在数组倒数第time个位置,
int temp = num[8 - time];
num[8 - time] = num[ranNum];
num[ranNum] = temp;
//返回数字
return num[8 - time];
}
}

在网上找的

❺ 哪位大师能告诉我我编的 java 数独解算程序 哪里有错误啊谢谢!

没看懂你的 考下来还要报错 我自己写了一个生成数独的方法 表示可以用
public class ShuDu {
/** 存储数字的数组 */
static int[][] n = new int[9][9];
/** 生成随机数字的源数组,随机数字从该数组中产生 */
static int[] num = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };

public static void main(String[] args) {
// 生成数字
for (int i = 0; i < 9; i++) {
int time = 0; // 尝试填充的数字次数
// 填充数字
for (int j = 0; j < 9; j++) {
// 产生数字
n[i][j] = generateNum(time);
// 如果返回值为0,则代表卡住,退回处理

// 退回处理的原则是:如果不是第一列,则先倒退到前一列,否则倒退到前一行的最后一列
if (n[i][j] == 0) {
if (j > 0) { // 不是第一列,则倒退一列
j -= 2;
continue;
} else {// 是第一列,则倒退到上一行的最后一列
i--;
j = 8;
continue;
}
}
if (isCorret(i, j)) {
// 填充成功
time = 0;// 初始化time,为下一次填充做准备
} else { // 继续填充
time++;// 次数增加1
// 继续填充当前格
j--;
}
}
} // 输出结果
for (int i = 0; i < 9; i++) {
for (int j = 0; j < 9; j++) {
System.out.print(n[i][j] + " ");
}
System.out.println();
}
}

/**
* * 是否满足行、列和3X3区域不重复的要求 * @param row 行号 * @param col 列号 *
*
* @return true代表符合要求
*/
public static boolean isCorret(int row, int col) {
return (checkRow(row) & checkLine(col) & checkNine(row, col));
}

/**
* * 检查行是否符合要求 *
*
* @param row
* 检查的行号 *
* @return true代表符合要求
*/
public static boolean checkRow(int row) {
for (int j = 0; j < 8; j++) {
if (n[row][j] == 0) {
continue;
}
for (int k = j + 1; k < 9; k++) {
if (n[row][j] == n[row][k]) {
return false;
}
}
}
return true;
}

/**
* * 检查列是否符合要求 * @param col 检查的列号 * @return true代表符合要求
*/
public static boolean checkLine(int col) {
for (int j = 0; j < 8; j++) {
if (n[j][col] == 0) {
continue;
}
for (int k = j + 1; k < 9; k++) {
if (n[j][col] == n[k][col]) {
return false;
}
}
}
return true;
}

/**
* 检查3X3区域是否符合要求 *
* @param row 检查的行号 *
* @param col 检查的列号 *
* @return true代表符合要求
*/
public static boolean checkNine(int row, int col) {
// 获得左上角的坐标
int j = row / 3 * 3;
int k = col / 3 * 3;
// 循环比较
for (int i = 0; i < 8; i++) {
if (n[j + i / 3][k + i % 3] == 0) {
continue;
}
for (int m = i + 1; m < 9; m++) {
if (n[j + i / 3][k + i % 3] == n[j + m / 3][k + m % 3]) {
return false;
}
}
}
return true;
}

/**
* 产生1-9之间的随机数字 *
* 规则:生成的随机数字放置在数组8-time下标的位置,随着time的增加,已经尝试过的数字将不会在取到 *
* 说明:即第一次次是从所有数字中随机,第二次时从前八个数字中随机,依次类推,*
* 这样既保证随机,也不会再重复取已经不符合要求的数字,提高程序的效率*
* * 这个规则是本算法的核心 *
* @param time 填充的次数,0代表第一次填充 *
* @return
*/
public static int generateNum(int time) {
// 第一次尝试时,初始化随机数字源数组
if (time == 0) {
for (int i = 0; i < 9; i++) {
num[i] = i + 1;
}
}
// 第10次填充,表明该位置已经卡住,则返回0,由主程序处理退回
if (time == 9) {
return 0;
}
// 不是第一次填充
// 生成随机数字,该数字是数组的下标,取数组num中该下标对应的数字为随机数字
int ranNum = (int) (Math.random() * (9 - time));
// 把数字放置在数组倒数第time个位置,
int temp = num[8 - time];
num[8 - time] = num[ranNum];
num[ranNum] = temp; // 返回数字
return num[8 - time];

}

阅读全文

与java数独算法相关的资料

热点内容
框架梁为什么是非加密区 浏览:993
什么app能把删了的照片恢复 浏览:360
公务员说程序员工资 浏览:400
怎样设置自己手机号码加密 浏览:700
服务器怎么设置登录地址 浏览:997
日本监控摄像头用什么APP 浏览:58
株洲歪胡子游戏源码 浏览:140
朔源码燕窝会假吗 浏览:279
php是否支持gd 浏览:925
旅游查攻略下载什么app 浏览:774
ps存储不在原始文件夹 浏览:37
android直播开发CSDN 浏览:750
apacheaddtypephp 浏览:501
女程序员美剧 浏览:639
安卓怎么隐身登录王者荣耀 浏览:854
通达信前五源码编写 浏览:19
gcc怎么编译qt程序 浏览:925
华为文件夹命名大全 浏览:383
php无限分类循环 浏览:41
北漂程序员营养餐 浏览:105