大榕树——让我们共成长!
大榕树 myDrs.org
您的位置:大榕树 \ 编程       |  Logo语言   |  Pascal语言   |  信息学奥赛   |  高考保送    |  HTML版本
|  Pascal语言>>Pascal练习>>简单背包问题         本站全文搜索: 友情提示:

简单背包问题
http://www.mydrs.org  6/21/2001  大榕树


[问题描述] 背包是一个简单的递归问题,要求是从n件物品中抽取几件,使之质量一定.该程序只求一组解.
输入:[KEYBOARD] 输出:[SCREEN]
10
1 2 3 4 5 6 7 8 9 12
9
--------------------------
5
1 2 3 4 5
45
2 3 4


------------------
NO ANSWER!


[问题分析] 使用递归算法完成.每件物品只有放入,不放入两种情况.

program knapProg;

const m=5;
var item:array[1..m] of integer;
i,w:integer;

function knap(a,b:integer):boolean;
begin
if item[a]=b then begin knap:=true;write(item[a]:8);exit;end;
if ((item[a]>b) and (a=m)) then begin knap:=false;exit;end;
if knap(a+1,b-item[a]) then begin knap:=true;write(item[a]:8);exit;end;
if not knap(a+1,b) then knap:=false;
end;

begin
writeln('Please input item weights:');
for i:=1 to m do read(item[i]);
writeln('Total weight:');
readln(w);
writeln;
if not knap(1,w) then writeln('NO ANSWER!!');
readln;
end.

作 者:MQL
来 源:Pascal Zone
共有6386位读者阅读过此文

  • 上篇文章高斯八皇后
  • 下篇文章折半查找

  • 发送邮件
    保存页面 打印文章 HTML版本 发表评论

    □- 近期热门文章 □- 相关文章
    1. NOIP2006竞赛大纲 [8306]
    2. 七类高中生具有保送资格 [5910]
    3. NOI2006获奖选手名单 [4955]
    4. 关于举办NOIP2006模拟赛的通告 [4106]
    5. Turbo Pascal各语句运行速... [3594]
    6. Turbo王者归来新Delphi免费... [3181]
    7. IOI2006我国4名选手全部获得金... [2945]
    8. 关于APIO2007与IOI2007... [2763]
    9. noip倒计时 by 枯叶蝴蝶 [2683]
    10. 朱泽园:思想上的金牌更重要 [2168]
    递归算法及其应用
    汉诺塔
    简单背包问题
    介绍递归
     

    关于本站 | 合作伙伴 | 联系方式
    大榕树 版权所有 ©1999-2006 www.myDrs.org 闽ICP备05000721号