科学家发现了一种神奇的材料,当其质量为 2 的幂时具有超导性
科学家制备了 n 份这种材料的样品,第 i 份样品的质量为 2 a i
为了得到质量更大的样品,可以把多份样品合并,这样得到的新样品的质量为 被合并的所有样品的质量之和
现在允许进行任意次合并,科学家希望最终得到的每一份样品都具有超导性。请问最终最少有多少份样品?
输入描述
第一行一个正整数 n
第二行 n 个数,表示 a i
输出描述
一行一个整数,表示最少得到多少份超导样品
用例输入 1
5
2 1 1 3 3
用例输出 1
2
提示
样例1解释
样品的质量分别依次为
2 ^2
2 ^1
2 ^1
2 ^3
2 ^3
,前 3 份样品可以合并为一份质量为 8 的样品,后 2 份可以合并为一份质量为 16 的样品。因此最少得到 2 份样品
数据范围
对于 20% 的数据,n≤10
对于 60% 的数据,n≤10000
对于 100% 的数据,1≤n≤10^6,0≤a i≤10 ^6
c++超导材料问题!
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 一起看海呦 2023-08-12 19:52关注
#include <bits/stdc++.h> using namespace std; int main() { int n; cin >> n; vector<int> a(n); for(int i = 0; i < n; i++) { cin >> a[i]; } sort(a.begin(), a.end()); int ans = 0; for(int i = 0; i < n; ) { if((a[i] & (a[i]-1)) == 0) { // 当前样品质量是2的幂 ans++; i++; } else { int j = i-1; while(j >= 0) { if((a[i] + a[j]) & (a[i] + a[j] - 1) == 0) { // 找到可以合并的 i++; break; } j--; } } } cout << ans << endl; return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥100 用数字代替ip主机号断与旋转链接号段
- ¥20 学校内手机热点不能使用
- ¥15 qwen模型微调训练时grad_norm为0.0或为nan
- ¥15 若依- Spring cloud-plus集成阿里云schedulerX再控制台应用管理找不到实例
- ¥15 用vs2022 fortran调试只无法查看数组的值,显示发生未指定的错误
- ¥50 SGD Gateway 是否可以与 SGD Server 装在一台服务器上?
- ¥15 gge梦幻西游的地图制作
- ¥15 对计算机的学习没有方向
- ¥15 用VBA抓取淘宝的发票号码和下载发票pdf遇到的问题
- ¥20 java excel导出有什么解决方案