题目来源: CodeForces
基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题
收藏
关注
现在有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示例
样例输出1 2
此题思路:
当你推数据的时候你会发现很有意思的事情,两个相同的幂可以变成一个+1的幂;
大致意思就是两个,0可以变成一个1,两个1可以变成1个2;
所以这道题就是模拟2进制的进位
#include <bits/stdc++.h>
#define maxn 2005555
typedef long long ll;
using namespace std;
ll a[maxn],ma,ans;
int main()
{
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
ll n;
cin >> n;
for(int i = 1; i <= n; i ++)
{
ll x;
cin >> x;
ma = max(ma,x);
a[x] ++;
}
for(int i = 0; i < ma + 1000; i ++)
{
if(a[i] >= 2)
{
a[i+1] += a[i] / 2;
a[i] %= 2;
}
ans += a[i];
}
cout << ans << endl;
return 0;
}