搜索与回溯5.3——自然数拆分

SSL 1661
洛谷 P2404 自然数的拆分问题
题目说明
任何一个大于1的自然数总可以拆分成若干个自然数之和。
例:
1:4=1+1+1+1
2:4=1+1+2
3:4=1+3
4:4=2+2
5:4=4

var
  n,l,m,x:longint;
  a:array[1..10000000]of longint;
procedure print;
var
  i:longint;
begin
  write(l,':',n,'=');
  for i:=1 to n do
   if a[i+1]<>0 then
    begin
      write(a[i],'+');
    end
    else break;
  writeln(a[i]);
end;

procedure search(k:longint);
var
  i:longint;
begin
  if k=0 then begin inc(l);print;exit; end
   else
  for i:=1 to k do
   if i>=x then
   begin
     inc(m);
     a[m]:=i;
     x:=i;
     search(k-i);
     x:=i-1;
     a[m]:=0;
     dec(m);
   end;
end;

begin
  readln(n);
  search(n);
end.

搜索解,每搜索一次便减去n的值,值为0则打印一行。
就这样,简单粗暴!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值