牛客(除2!)

链接:登录---专业IT笔试面试备考平台_牛客网

来源:牛客网

题目描述

给一个数组,一共有 n n\ n 个数。

你能进行最多 k k\ k 次操作。每次操作可以进行以下步骤:

  • 选择数组中的一个偶数 aia_iai,将其变成 ai/2a_i/2ai/2 。

现在你进行不超过 k k\ k 次操作后,让数组中所有数之和尽可能小。请输出这个最小的和。

思路:

遍历一遍数组,偶数保存在一个大堆中,奇数直接加在结果中。然后每次从堆顶提取元素,即当前最大的偶数,对其除以2,若是奇数则直接加入结果中,若是偶数则重新放入大堆中。

注意:本题结果可能超过INT的范围,因此用long long。

复制代码
#include<algorithm>
#include<iostream>
#include<vector>
#include<math.h>
#include<queue>

using namespace std;

struct cmp
{
    bool operator()(int a,int b)
    {
        return a<b;
    }
};

int main()
	{ 
    int n,k;
    cin>>n>>k;
    priority_queue<int,vector<int>,cmp>qn;
    long long ret=0;
    for(int i=0;i<n;i++)
    {
        int kk=0;
        cin>>kk;
        if(kk%2==0)
            qn.push(kk);
        else
            ret+=kk;
    }
     
    while(k--&&qn.size())
    {
        int kk=qn.top()/2;
        qn.pop();
        if(kk%2==0)
            qn.push(kk);
        else
            ret+=kk;
    }
    while(qn.size())
    {
        ret+=qn.top();
        qn.pop();
    }
    cout << ret;

return 0;
}
相关推荐
We་ct3 分钟前
LeetCode 4. 寻找两个正序数组的中位数:二分优化思路详解
前端·数据结构·算法·leetcode·typescript·二分
仍然.31 分钟前
算法题目---位运算
算法
计算机安禾40 分钟前
【数据结构与算法】第10篇:项目实战:学生信息管理系统(线性表版)
开发语言·数据结构·算法·visual studio
q_354888515340 分钟前
计算机毕业设计:汽车数据可视化与智能分析平台 Django框架 Scrapy爬虫 可视化 车辆 懂车帝大数据 数据分析 机器学习(建议收藏)✅
算法·信息可视化·django·flask·汽车·课程设计·美食
FakeOccupational1 小时前
【电路笔记 通信】IEEE 1588精密时间协议(PTP):数学假设+时间同步链路建模+消除主从偏差算法
笔记·算法
客卿1231 小时前
最小生成树(贪心)--构造回文串(字符串 + 回文判断 + 构造)
java·开发语言·算法
88号技师1 小时前
2026年3月中科院一区SCI-赏金猎人优化算法Bounty Hunter Optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
再卷也是菜1 小时前
算法基础篇(12)Trie树
算法·字典树
小糯米6011 小时前
C++ 单调栈原理与模板
开发语言·c++·算法
常利兵1 小时前
Android 集合探秘:ArrayMap 与 SparseArray 的奇妙之旅
android·算法·哈希算法