- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
八数码问题源代码
自己用宽度优先算法写的八数码问题,有代码,有注释,有截图
中间动态变化过程截图省略
……
源代码:
EightDigital.java
package eightDigitalProblem;
import java.util.*;
public class EightDigital {
public static void main(String[] args) {
// TODO Auto-generated method stub
//EightDigital ed = new EightDigital();
//ed.launch();
MyFrame mf = new MyFrame();
mf.launchMyFrame();
}
public Node launch(int [] startData, int [] endData){
//起始结点赋值 283164705
//结束结点赋值 123804765
int[] array0 = new int[9];
Node s0 = new Node(array0);
Node s = new Node(startData);
s.setDepth(0);
s.setStep(0);
s.setFatherNode(s0);
LinkedListNode open = new LinkedListNode(); //open集合
open.add(s); //添加初始点
LinkedListNode closed = new LinkedListNode(); //closed集合
Node n;
while(true){ //循环
if(open.isEmpty()){
System.out.println(fail);
System.exit(0);
}
n = open.getFirst();
if(goal(n, endData)){
System.out.println(success); //找到目标结点了
break;
}
closed.add(n); //把结点加入到closed表中
open.removeFirst(); //删除最前面的结点
LinkedListNode m = expand(n); //扩展结点
while(!m.isEmpty()){
open.add(m.removeFirst());
}
}
//找到目标结点
n.display();
return n;
}
public boolean goal(Node n, int [] endData){
int[] array = new int[9];
//目标结点赋初值
array[0] = 1;
array[1] = 2;
array[2] = 3;
array[3] = 8;
array[4] = 0;
array[5] = 4;
array[6] = 7;
array[7] = 6;
array[8] = 5;
//Node s = new Node(array); //目标结点
Node s = new Node(endData); //目标结点
if(s.equals(n)){
return true;
}else{
return false;
}
}
public LinkedListNode expand(Node n){ //n结点向外扩展,返回扩展的结点集合
LinkedListNode temp = new LinkedListNode();
int zeroPosition = n.getZeroPosition(n); //记录0(空格)的位置
if(rightMove(zeroPosition)){ //空格可以向右移动
Node newNode = new Node(n); //创造一个新结点
newNode.getArray()[zeroPosition] = newNode.getArray()[zeroPosition+1]; //空格右移
newNode.getArray()[zeroPosition+1] = 0;
if( !n.getFatherNode().equal
您可能关注的文档
最近下载
- 渠道护砌工程施工方案砼预制块护坡施工渠道砼工程砼格埂.docx VIP
- 气调库工程项目可行性研究报告.docx
- 2025年二级矿井维修电工(技师)技能认定理论考试题库资料(含答案).pdf
- 功能性食品学 课件 第8章 益生菌及其活性代谢物.pptx
- 实验室质量管理体系文件.docx VIP
- 电工高级技师实操考试试卷.pdf VIP
- 初中阶段初阶词汇初级-如何记单词.docx VIP
- 中文版安德森吞咽困难量表的信效度和临床应用评价.pdf VIP
- (正式版)D-L∕T 611-2016 300MW~600M级机组煤粉锅炉运行导则.docx VIP
- BSL实验室生物安全管理体系文件.docx VIP
文档评论(0)