- 浏览: 319148 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (299)
- 私人 (3)
- linux (22)
- web service (1)
- java applet (1)
- java (41)
- c# (1)
- socket (1)
- android (10)
- htc (1)
- root (1)
- ftp (3)
- 系统备份 (0)
- jquery (3)
- 图表 (1)
- 实用 (4)
- web (9)
- css (3)
- java applet mplayer (1)
- mplayer (4)
- javascript (8)
- eclipse (1)
- 正则表达式 (1)
- jmf (1)
- tomcat (6)
- 驱动 (1)
- 嵌入式 (1)
- usb (3)
- ffmpeg (1)
- player (1)
- encode (1)
- ajax (1)
- 单纯形复法 (1)
- rom (1)
- ndk (1)
- 打印 (1)
- vs2010 (2)
- myeclipse注册机 (1)
- c++ (5)
- capture (0)
- 串口 (1)
- windows (2)
- mingw (1)
- 网卡 (1)
- 绿色版 (1)
- cywin (1)
- x264 (1)
- 恢复文件 (1)
- servlet init 连数据库 (1)
- 51 单片机 (1)
- 操作系统 (1)
- vlc (3)
- 网线 (1)
- CListBox (1)
- mfc (1)
- setTimer (1)
- 分屏 (1)
- 供求信息 (1)
- 导航 (1)
- 批处理 (1)
- dos (1)
- mysql (5)
- MySQL新建用户 (1)
- demo (1)
- vc (1)
- webservice (1)
- 书签 (1)
- 浏览器 (1)
- spring mvc (1)
- excel (1)
- VPN (0)
- sql (1)
- pdf (3)
- arp (1)
- jsp (2)
- IE (1)
- html (1)
- test (3)
- httpclient (1)
- spring mvc 上传 (1)
- easyui (1)
- mybatis (1)
- spring (1)
- 微信 (1)
- weixin (2)
- pay (2)
- maven (2)
- fastdfs (2)
- ELK (2)
- logstash (1)
- rocketMQ (0)
- jmeter (0)
- 测试 (0)
- softether (0)
- util (0)
最新评论
-
ice24:
ftp client applet -
wuzijingaip:
499700647 写道你好,看了您的文章《ftp clien ...
ftp client applet -
zxcv193188:
感谢楼主
java JMF的使用 -
499700647:
你好,看了您的文章《ftp client aplet》很受启发 ...
ftp client applet -
JoeBaby_:
非常感谢,看文档的时候觉得JMF好难的样子,但是看过代码后思路 ...
java JMF的使用
/** * 数独程序 */ 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 线程池
2018-08-07 11:26 290package com.fx.test; impor ... -
ftppool-demo
2018-05-24 09:16 278ftp pool demo -
java 遍历文件夹和文件
2018-03-28 11:39 420public static void trave ... -
java 流写入本地文件
2018-03-27 10:17 761private static void wr ... -
java 字符串转为流
2018-03-27 10:03 450public static Inpu ... -
ftputil + ftpclientPOOL
2018-03-22 14:39 355ftputil + ftpclientPOOL -
微信支付网上找的Demo
2017-06-22 17:58 266微信支付网上找的Demo,当时做支付时有些地方就参考了他,作者 ... -
Jsoup get post
2016-12-21 17:11 353package com.test; import ... -
java 面包屑导航
2016-10-24 15:08 439类似面包屑导航,抛砖引玉 后台维护一个访问路径的列表 ... -
获取n年前日期
2016-03-08 14:42 490/** * 获取n年前日期 ... -
httpclient访问需要登录才能访问的数据
2015-04-23 22:10 541package com.grkj.modules.tree ... -
jsp获取uri 以及绝对路径
2014-07-01 17:06 470得到从根路径到当前jsp页面的路径: request.ge ... -
JAVA导出PDF实例
2014-05-13 14:39 850一、直接导出成PDF Java代码 ... -
Java HTML直接导出PDF
2014-05-13 12:18 1140Java HTML直接导出PDF 对于java中如何从h ... -
java生成PDF
2014-05-13 12:11 441一、前言 在企业 ... -
linux下JAVA环境变量的设置
2014-03-21 14:05 497在终端中输入命令 vi /etc/profile.d/j ... -
Java读取Excel内容
2014-02-20 16:34 511所需jar 下后面 import java.io.B ... -
myeclipse9
2012-08-28 16:13 666import java.io.BufferedReader; ... -
java 打印
2012-08-07 18:03 896import java.awt.BasicStroke; ... -
java 单纯形复法
2012-06-27 11:37 773java 单纯形复法
相关推荐
java数独生成算法及基于此算法的android数独游戏APK
JAVA的数独游戏代码,随机生成数独,如果有三个难度可选
可以根据设置不同难度生成9x9数独题
这是一个J2ME的数独游戏,里面有详细的代码和生成的jar程序,让你学会制作这个小游戏。这个游戏,相信朋友们都知道的,以前也经常玩的,今天放出一个基于Java的J2me手机版的,学习J2me编程的朋友有资料看了。
由java编写的数独游戏,相当完美的java程序!具有不错的可视化界面!
该方法通过回溯的方法实现了数独的一个完整的棋盘的生成,效率有待提高(ps:只是个逻辑部分,没上传完整实现)
用JAVA Swing实现的一个数独的生成和解迷的小工具,适合初学者
课程设计要求基于java编写程序完成数独游戏,能够随机生成九宫格的已知数,并通过算法检测所填数字是否满足数独条件。数独是锻炼脑筋的好方法,提高逻辑思维能力。 基于Java编写数独游戏,具体要求如下: 1、游戏的...
是关于九宫格数独游戏一部分的实现功能,有什么不好的,望大家多多包涵……
根据网上的andriod开发教程资源所开发的数独应用。是完整的数独代码,功能基本实现。
自己用GUI写的一个数独小游戏。。可选择难度,生成一个只有唯一解的数独。。可显示答案,玩家也可以自己做题。代码+算法全在里面
数独游戏 用Java编写的数独游戏,可以生成和解决难题。
用java swing编写的数独破解器升级版。 能破解初级、中级、高级和顶级(世界上最难的数独破解时间只需235毫秒)的数独。 项目源码不依赖任何第三方jar包,生成的jar只有27k。 破解步骤: 1.点击设置初始数据,将你要...
经典的数独游戏,9*9的大九宫格,gui界面
是一个最快速度求解,最快速度生成的代码.使用深度递归调用, 已经测试4000个以上的数独,最慢一次求解使用1秒不到,最快一次求解14微妙
一、数独说明:数独由九行,九列组成,又分为顺序排列的九宫。每行、每列及每宫都包含九个格,九个格中填放1到9的不重复的数字。 二、自动计算原理(三步法): 1、基础法:找出空格中唯一可填的数字。方法是,先...
这是一个用java编程的数独9*9的实验代码。
python
数独生成器 只是一个小型数独板 java 生成器利用蛮力技术生成随机 9x9 数独板