卖欧教资料之搜索作业.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
卖欧教资料之搜索作业

搜索专题作业: 看书:队列部分:数据结构与程序实现P130-P187 搜索训练题目: tyvj网址: rqnoj网址: 深搜: 易: tyvj 1127:数细胞 tyvj 1171:输入自然数n,然后将其拆分成由若干数相加的形式,参与加法运算的数可以重复。 难: tyvj 1131:虫食算 NOIP2004第四题 tyvj 1120:靶形数独 NOIP2009第四题 宽搜(广搜): rqnoj 195:走迷宫 tyvj 1074:武士风度的牛 8数码:数据结构与程序实现P139 选作: poj搜索题目: 入门: 搜索(至少4题) (1011,1033,1129,2049,2056,2488) 初级: (1)深度优先搜索 (poj2488,poj3083,poj3009,poj1321,poj2251) (2)广度优先搜索(poj3278,poj1426,poj3126,poj3087.poj3414) (3)简单搜索技巧和剪枝(poj2531,poj1416,poj2676,1129) 中级: (1)最优化剪枝和可行性剪枝 (2)搜索的技巧和优化 (poj3411,poj1724) (3)记忆化搜索(poj3373,poj1691) 高级: (1)较麻烦的搜索题目训练(poj1069,poj3322,poj1475,poj1924,poj2049,poj3426) (2)广搜的状态优化:利用M进制数存储状态、转化为串用hash表判重、按位压缩存储状态、双向广搜、A*算法. (poj1768,poj1184,poj1872,poj1324,poj2046,poj1482) (3)深搜的优化:尽量用位运算、一定要加剪枝、函数参数尽可能少、层数不易过大、可以考虑双向搜索或者是轮换搜索、 IDA*算法. (poj3131,poj2870,poj2286) 附:8数码例程 program T8numbfs; uses sysutils; const dir:array[1..4] of longint=(-3,3,-1,1); maxn=362880; type TState = array[1..9]of longint; TNode=record father:longint; {父指针} dep:longint; {深度} x0:longint; {0的位置} state:Tstate; {棋盘状态 } end; var source,target:TState; {初始状态和目标状态} htarget:longint;//目标状态hash值 q:array[0..maxn] of TNode; {状态队列 } L,R:longint; { 区间(L,R]表示队列里边的节点} hash:array[0..362880] of boolean; {hash表,每个状态唯一对应一个数} time:real;//卡时 function gethash(x:tstate):longint; var s,total,i,j,k:longint; begin total:=0; k:=1; for i:=2 to 9 do begin k:=k*(i-1);//第i位的权值为(i-1)! s:=0; for j:=1 to i-1 do if x[j]x[i] then inc(s);//统计棋盘上第i位左边比它小的数的个数 total:=total+s*k; end; //exit(total); gethash:=total; end; procedure getinfo; {读入初始和目标节点} var i,j:longint; begin for i:=1 to 3 do for j:=1 to 3 do read(source[(i-1)*3+j]); for i:=1 to 3 do for j:=1 to 3 do read(target[(i-1)*3+j]); htarget:=gethash

文档评论(0)

pxoc653 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档