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! 展开
输入样例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! 展开
展开全部
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.
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 广告
2024-08-19 广告
威孚(苏州)半导体技术有限公司是一家专注生产、研发、销售晶圆传输设备整机模块(EFEM/SORTER)及核心零部件的高科技半导体公司。公司核心团队均拥有多年半导体行业从业经验,其中技术团队成员博士、硕士学历占比80%以上,依托丰富的软件底层...
点击进入详情页
本回答由威孚半导体技术提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询