标签:new chmod sizeof nbsp arch sub sum fabs eof
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 7677 Accepted Submission(s): 3187
1 //a克砝码有三种状态,放在天平的左端可以认为是x^-a,不放是1,放在右边是x^a,这样(x^-a,1,x^a)。但是负的重量没法用数组存,所以 2 //可以用abs(k-j)表示左右砝码的差得到c2[abs(k-j)]+=c1[j]; 3 #include<bits\stdc++.h> 4 using namespace std; 5 int n,sum,a[102],c1[10004],c2[10004]; 6 void solve() 7 { 8 memset(c1,0,sizeof(c1)); 9 memset(c2,0,sizeof(c2)); 10 c1[0]=1;c1[a[1]]=1; //第一个表达式的系数 11 for(int i=2;i<=n;i++) 12 { 13 for(int j=0;j<=sum;j++) 14 { 15 int k=0; 16 if(k+j<=sum) 17 c2[k+j]+=c1[j]; 18 k=a[i]; 19 if(k+j<=sum) 20 c2[k+j]+=c1[j]; 21 int tem=fabs(k-j); 22 if(tem<=sum) 23 c2[tem]+=c1[j]; 24 } 25 for(int j=0;j<=sum;j++) 26 { 27 c1[j]=c2[j]; 28 c2[j]=0; 29 } 30 } 31 } 32 int main() 33 { 34 while(scanf("%d",&n)!=EOF) 35 { 36 sum=0; 37 for(int i=1;i<=n;i++) 38 { 39 scanf("%d",&a[i]); 40 sum+=a[i]; 41 } 42 solve(); 43 int t=0,ans[10000]; 44 for(int i=1;i<=sum;i++) 45 if(c1[i]==0) 46 { 47 t++; 48 ans[t]=i; 49 } 50 printf("%d\n",t); 51 if(t){ 52 for(int i=1;i<t;i++) 53 printf("%d ",ans[i]); 54 printf("%d\n",ans[t]); 55 } 56 } 57 return 0; 58 }
标签:new chmod sizeof nbsp arch sub sum fabs eof
原文地址:http://www.cnblogs.com/--ZHIYUAN/p/6103211.html