pascal子集和问题

一个集合里有N个数,取S个数和为R。输入样例15(有五个数)10(和为10)22645(这个集合)输出样例222664输入样例253(不用解释了吧)24324输出样例2n... 一个集合里有N个数,取S个数和为R。
输入样例1
5(有五个数)10(和为10)
2 2 6 4 5(这个集合)
输出样例2
2 2 6
6 4
输入样例2
5 3 (不用解释了吧)
2 4 3 2 4
输出样例2
no solution!
展开
 我来答
喜扬扬790
2010-04-17 · TA获得超过495个赞
知道答主
回答量:344
采纳率:0%
帮助的人:0
展开全部
var
n,m,p,flag,i:longint;
a,b:array[1..1000]of longint;
procedure dfs(now,sum:longint);
var i,j,s:longint;
begin
if(now=n+1) then exit;
if (sum=m) and (p>1) then begin
for i:=1 to p do write(a[b[i]],' ');
writeln;
flag:=1;
end;
for i:=now+1 to n do
if a[i]+sum<=m then begin
inc(p);
b[p]:=i;
dfs(i,sum+a[i]);
dec(p);
end;
end;

begin
read(n,m);
for i:=1 to n do read(a[i]);
dfs(0,0);
if flag=0 then writeln('no solution!');
end.
威孚半导体技术
2024-08-19 广告
威孚(苏州)半导体技术有限公司是一家专注生产、研发、销售晶圆传输设备整机模块(EFEM/SORTER)及核心零部件的高科技半导体公司。公司核心团队均拥有多年半导体行业从业经验,其中技术团队成员博士、硕士学历占比80%以上,依托丰富的软件底层... 点击进入详情页
本回答由威孚半导体技术提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式