网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.你所需要的《Just Java 2》.
.实现游戏开发中的屏幕滚动功能.
.在ejb中直接利用jdbc读取数据库记.
.Java咖啡馆(7)——大话面向对象(.
.创建 JSF Web 项目和页面模板(1.
.网友杂谈各种app Server.
.java中的集合类.
.java中实现IP地址的各种表现形式.
.对Java嵌套类的讨论.
.Hibernate查询语言:HQL.
.取余赋值运算符 (%=).
.从TXT文件中一行一行读取数字.
.java在Linux下的web应用(1).
.基于MVC的Struts在财务系统中的应.
.诺基亚亲密接触Eclipse 深化开源.
.微软代码.
.java变量的赋值与传递.
.一些面向对象的设计法则(1).
.学习JAVA的第一方案 (转贴).
.让你学习控制住 Web 2.0的方向盘.

情人碰面的问题:JAVA代码概述

发表日期:2008-1-5



  /*
  * 8情人问题:
  *
  * 问题描述:
  * 在一个8×8的棋盘里放置8个情人,要求每个情人两两之间不相冲突
  *(在每一横列,竖列,斜列只有一个情人)。
  *
  * 数据表示:
  * 用一个 8 位的 8 进制数表示棋盘上情人的位置:
  * 比如:45615353 表示:
  *    第0列情人在第4个位置
  *    第1列情人在第5个位置
  *    第2列情人在第6个位置
  *    。。。
  *    第7列情人在第3个位置
  *
  * 循环变量从 00000000 加到 77777777 (8进制数)的过程,就遍历了情人所有的情况
  * 程序中用八进制数用一个一维数组 data[] 表示
  *
  * 检测冲突:
  *   横列冲突:data[i] == data[j]
  *   斜列冲突:(data[i]+i) == (data[j]+j) 或者 (data[i]-i) == (data[j]-j)
  *
  * 好处:
  * 采用循环,而不是递规,系统资源占有少
  * 可计算 n 情人问题
  * 把问题线性化处理,可以把问题分块,在分布式环境下用多台计算机一起算。
  *
  * ToDo:
  *  枚举部分还可以进行优化,多加些判定条件速度可以更快。
  *  输出部分可以修改成棋盘形式的输出
  *
  * @author cinc 2002-09-11
  *
  */
  
  public class Queen {
  int size;
  int resultCount;
  
  public void compute ( int size ) {
  this.size = size;
  resultCount = 0;
  int data[] = new int[size];
  int count; // 所有可能的情况个数
  int i,j;
  
  // 计算所有可能的情况的个数
  count = 1;
  for ( i=0 ; i<size ; i++ ) {
  count = count * size;
  }
  // 对每一个可能的情况
  for ( i=0 ; i<count ; i++ ) {
  // 计算这种情况下的棋盘上情人的摆放位置,用 8 进制数表示
  // 此处可优化
  int temp = i;
  for ( j=0 ; j<size ; j++ ) {
  data [j] = temp % size;
  temp = temp / size;
  }
  // 测试这种情况是否可行,假如可以,输出
  if ( test(data) )
  output( data );
  }
  }
  
  /*
  * 测试这种情况情人的排列是否可行
  *
  */
  public boolean test( int[] data ) {
  int i,j;
  for ( i=0 ; i<size ; i++ ) {
  for ( j=i+1 ; j<size ; j++ ) {
  // 测试是否在同一排
  if ( data[i] == data[j])
  return false;
  // 测试是否在一斜线
  if ( (data[i]+i) == (data[j]+j) )
  return false;
  // 测试是否在一反斜线
  if ( (data[i]-i) == (data[j]-j) )
  return false;
  }
  }
  return true;
  }
  
  /*
  * 输出某种情况下情人的坐标
  *
  */
  public void output ( int[] data ){
  int i;
  System.out.print ( ++resultCount + ": " );
  for ( i=0 ; i<size ; i++ ) {
  System.out.print ( "(" + i + "," + data[i] + " " );
  }
  System.out.println ();
  }
  
  //main()就是在这里.
  public static void main(String args[]) {
  (new Queen()).compute( 8 );
  }
  }
上一篇:查询页面显示进度条,load成功后隐去进度条 人气:1647
下一篇:教你如何利用JAVACC将HQL转换为SQL 人气:839
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐