牛客(除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;
}
相关推荐
Lips6111 小时前
2026.1.20力扣刷题笔记
笔记·算法·leetcode
2501_941329721 小时前
YOLOv8-LADH马匹检测识别算法详解与实现
算法·yolo·目标跟踪
洛生&1 小时前
Planets Queries II(倍增,基环内向森林)
算法
小郭团队2 小时前
1_6_五段式SVPWM (传统算法反正切+DPWM2)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·matlab·dsp开发
小郭团队2 小时前
1_7_五段式SVPWM (传统算法反正切+DPWM3)算法理论与 MATLAB 实现详解
开发语言·嵌入式硬件·算法·matlab·dsp开发
鱼跃鹰飞2 小时前
Leetcode347:前K个高频元素
数据结构·算法·leetcode·面试
bybitq2 小时前
LeetCode236-二叉树的最近公共祖先(LCA)问题详解-C++
算法·深度优先
啊阿狸不会拉杆2 小时前
《数字图像处理》第 7 章 - 小波与多分辨率处理
图像处理·人工智能·算法·计算机视觉·数字图像处理
程序猿炎义3 小时前
【Easy-VectorDB】Faiss数据结构与索引类型
数据结构·算法·faiss
天赐学c语言4 小时前
1.20 - x的平方根 && vector的扩容机制以及删除元素是否会释放内存
c++·算法·leecode