- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《软件技术基础》结课大作业姓名王家毅学号 120611325日期 2014.06.191利用减半递推技术,写出求长度为n的数组中最大元素的递归算法#include iostreamusing namespace std;intmaxa(int a[], int m, int n){ int d,d1,d2;if ( m==n ) return( a[m-1] );else { d1 = maxa( a,m,(m+n)/2 ); //求数组中前半部分的最大值 d2 = maxa( a,(m+n)/2+1,n ); } //求数组中后半部分的最大值if (d1d2) d=d1; else d=d2;return(d);}2编写用回溯法求解n皇后的算法#include iostream.h#include math.hboolplace(int k, int *X){????????inti;????????i=1;????????while(ik)????????{??????????????????if((X[i]==X[k])||(abs(X[i]-X[k])==abs(i-k)))??????????????????return false;??????????????????i++;?????????}????????return true;}void Nqueens(intn,int *X){???????int k;???????X[1]=0;k=1;???????while(k0)???????{?????????????X[k]=X[k]+1; //不断的在解空间里从小到大的试探??????????????while((X[k]=n)(!place(k, X)))??????????????????????X[k]=X[k]+1;?????????????????????//不符合条件的马上再取解空间的下一个值来试探。??????????????if(X[k]=n)???//找到了一个位置,而且是合法的??????????????????if(k==n)???//是不是最后一个皇后,若是则得出一个完整解?????????????????{??????????????????????????for(inti=1;i=n;i++)??????????????????????????coutX[i] ;??????????????????????????cout\n;???????????????????}??????????????????else????//若不是最后一个皇后,则给下一个皇后找位置?????????????????{??????????????????????????k=k+1;??????????????????????????X[k]=0;?????????????????}???????????????else??????k=k-1;??//若是找了全部的列都无法放置某个皇后,则回溯到上一个k的情况,让上一个k再往下试????????}?}3给定n个城市间的距离,求从一个城市0出发经过其他城市一次且一次的一条最短路径void main(){functionDijkstra(G,w,s)for each vertex v in V[G]d[v] := infinityprevious[v] := undefined?//对n个顶点进行初始化,显然是O(n)d[s] := 0S := empty set?//O(1)V := set of all vertices? //n个顶点加入队列O(n)While V is not an empty set?//从这一行可以看出n遍循环,下面调用Extract_Min(v),此过程需要搜寻整个数组,一次操作时间是O(n),共O(n^2)u := Extract_Min(v)S := S union{u}for each edge(u,v) outgoing from u?//拓展边(u,v),共E条边,因此是O(E)if d[v] d[u] + w(u,v)d[v] := d[u] + w(u,v) previous[v] := u?//总共合起来是O(E+n^2);所有步骤合起来就是O(n)+O(1)+O(n)+O(E+n^2),即O(n^2)。}4将单链表看做二叉树,编写递归程序打印单链表#include?#include?#include?#include?typedefstruct node{char c;int count;struct node *left,*right;}bnode;bno
文档评论(0)