- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
“背包问题”的算法
问题基本描述:有一个背包,能盛放的物品总重量为S,N件物品,其重量分w1,w2,...wn,希望从N件物品中S。
递归算法
?
#include?stdio.h#define?N?7#define?S?15int?w[N+1]?=?{0,1,2,3,4,5,6,7};int?knap(int?s,?int?n){????if(s?==?0)????????return?1;????if(s??0?||?s?0??n??1)????????return?0;????if(knap(s?-?w[n],?n-1))????{????????printf(%4d ,?w[n]);????????return?1;????}????return?knap(s,?n-1);}void?main(){????if(knap(S,?N))????????printf(OK! );????else????????printf(NO! );????getchar();}
?非递归
?
#include?stdio.h#define?N?7#define?S?15typedef?struct{????int?s;????int?n;????int?job;}KNAPTP;int?w[N+1]?=?{0,1,4,3,4,5,2,7};int?knap(int?s,?int?n){????KNAPTP?stack[100],?x;????int?top,?k,?rep;????x.s?=?s;?x.n?=?n;????x.job?=?0;????top?=?1;?stack[top]?=?x;????k?=?0;????while(top??0??k?==?0)????{????????x?=?stack[top];????????rep?=?1;????????while(!k??rep)????????{????????????if(x.s?==?0)????????????????k?=?1;?//caught?an?answer????????????else?if(x.s??0?||?x.n?=?0)????????????????rep?=?0;????????????else????????????{????????????????x.s?=?x.s?-?w[x.n--];????????????????x.job?=?1;????????????????stack[++top]?=?x;????????????}????????}????????if(!k)?//watch?rep?=?0;????????{????????????rep?=1;????????????while(top?=?1?rep)????????????{????????????????x?=?stack[top--];????????????????if(x.job?==?1)????????????????{????????????????????x.s?+=?w[x.n?+?1];????????????????????x.job?=?2;?//change?it?as?discard?one????????????????????stack[++top]?=?x;????????????????????rep?=?0;????????????????}????????????}????????}????}????if(k)?//?found?an?answer????{????????while(top?=?1)????????{????????????x?=?stack[top--];????????????if(x.job?==?1)????????????????printf(%d ,?w[x.n?+?1]);????????}????}????return?k;}void?main(){????if(knap(S,?N))????????printf(OK! );????else????????printf(NO );????getchar();}
求解部分的循环执行条件是堆栈不空且未找到解,因为当堆栈空的时候表示程序已经穷尽了所有的可能,这是使用堆栈的程序的一般特征。(利用堆栈对不在结果集 中的数据o的位置存放S和N,注意top的初始1并不是int w[N+1] = {0,1,1,1,1,1,1,1};堆top=1或者top0,此stack[0]的内容和含
文档评论(0)