【笔试】算法的暴力美学——牛客 NC213140 :除2!

一、题目描述

二、算法原理

思路:贪心 + 堆

建立一个共识:所有的偶数中,依次升序,那么我们只要把最大的偶数/2就比任何偶数/2的所有偶数的总值要小,例如:2 4 6 ,sum = 12,2 4 3 ,sum = 9,2 2 6 ,sum = 10,1 4 6 ,sum = 11

1)首先建立个大根堆,当我们存储数据时,创建一个变量记录所有值的和,当输入的数据为偶数时入堆;

2)此时我们的大根堆里面全是偶数,而且我们的 sum 也记录所有的值的和,我们使用一个 while 循环(堆不为空,k不等于0,而且要 k 要 -- ,因为堆里面全是偶数,所以最少要进行一次 k 操作),在 while 循环中,我们拿到堆顶的元素,记住要出堆,我们把这个元素直接除2,此时 sum 要减去元素/2的值,因为 sum 记录是所有(包含偶数没除2)的值,元素/2 的值要再次判断该值是否是偶数,是偶数就入堆;

三、代码实现

cpp 复制代码
#include<iostream>
#include<vector>
#include<queue>
using namespace std;

int main()
{
    long long n = 0, k = 0;
    cin >> n >> k;
    
    //准备工作
    priority_queue<long long> que;//大根堆
    long long sum = 0;
    for(long long i = 0; i < n; i++)
    {
        long long m = 0;
        cin >> m;
        sum += m;
        if(m % 2 == 0)//偶数入堆
        {
            que.push(m);
        }
    }

    while(!que.empty() && k--)
    {
        long long tmp = que.top() / 2;
        que.pop();//出堆
        sum -= tmp;//总值减去
        if(tmp % 2 == 0) que.push(tmp);
    }
    
    cout << sum << endl;
    
    return 0;
}
相关推荐
杜子不疼.5 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
石山代码6 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家6 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事6 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院6 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet7 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
张小姐的猫8 小时前
【Linux】多线程 —— 线程互斥
linux·运维·服务器·c++
m0_6294947310 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户10 小时前
用队列实现栈
数据结构·算法