现在有n个货物,第i个货物的重量是 2wi 。每次搬的时候要求货物重量的总和是一个2的幂。问最少要搬几次能把所有的货物搬完。
样例解释:
1,1,2作为一组。
3,3作为一组。
Input
单组测试数据。 第一行有一个整数n (1≤n≤10^6),表示有几个货物。 第二行有n个整数 w1,w2,...,wn,(0≤wi≤10^6)。
Output
输出最少的运货次数。
Input示例
样例输入1 5 1 1 2 3 3
Output示例
样例输出12
已经有一个月沒有编程了,有点想放弃了,感觉自己还是那么的菜 这一道是二进制问题 给出的数据都是2^w 整好和二进制很吻合 二进制进位 10000+1000+100+10+1+1=100000 1+1=10,10+10=100,100+100=1000……
#include<stdio.h> #include<string.h> #define maxn 1000100 int w[maxn]; int main() { int n,i; while(scanf("%d",&n)!=EOF) { memset(w,0,sizeof(w)); while(n--) { scanf("%d",&i); w[i]++; } int sum=0; for(int j=0;j<maxn;++j) { if(w[j]>1) { w[j+1]+=w[j]/2; w[j]%=2; } if(w[j]==1) ++sum; } printf("%d\n",sum); } return 0; }