码迷,mamicode.com
首页 > 其他好文 > 详细

集合划分(subset)

时间:2015-08-06 23:51:51      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:

对于从1到N(1<=N<=3)的连续整数集合,划分成两个子集合,使得每个集合的数字之和相等。举个例子,如果N=3,对于{1,2,3}能划分成两个子集合,他们每个的所有数字和是相等的:{3} and {1,2} 这是唯一的一种分法(交换集合位置被认为是同一种划分方案,因此不会增加划分方案总数)。如果N=7,有四种方法能划分集合{1,2,3,4,5,6,7},每一种分法的子集合各数字和是相等的: {1,6,7} and {2,3,4,5};{2,5,7} and {1,3,4,6}; {3,4,7} and {1,2,5,6};{1,2,4,7} and {3,5,6}


var f:array[0..100,0..100] of longint;
    n,s,i,j:longint;
begin
  fillchar(f,sizeof(f),0);
  read(n);
  s:=n*(n+1) div 2;
  if (s mod 2=1) then
   begin
    writeln(0);
    halt;
   end
//总和是奇数无法平分直接输出零
  else
   begin
    f[n,0]:=1;
    f[n,n]:=1;
    s:=s div 2;
//也可以一开始div4
    for i:=n-1 downto 2 do
     for j:=0 to s do
      begin
       f[i,j]:=f[i+1,j];
       if j-i>=0 then f[i,j]:=f[i,j]+f[i+1,j-i];
//f[i,j]表示从i..n中取数得和为j的方案数,j-i意为取完数了
      end;
    writeln(f[2,s]);
   end;
end.

 

集合划分(subset)

标签:

原文地址:http://www.cnblogs.com/yangqingli/p/4709308.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!