【笔试】算法的暴力美学——牛客 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;
}
相关推荐
汀、人工智能2 小时前
[特殊字符] 第66课:跳跃游戏
数据结构·算法·数据库架构·图论·bfs·跳跃游戏
汀、人工智能2 小时前
[特殊字符] 第70课:加油站
数据结构·算法·数据库架构·图论·bfs·加油站
wsoz2 小时前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组
y = xⁿ2 小时前
【LeetCode】双指针:同向快慢针
算法·leetcode
啊哦呃咦唔鱼2 小时前
LeetCode hot100-105从前序与中序遍历序列构造二叉树
算法
favour_you___2 小时前
2026_4_8算法练习题
数据结构·c++·算法
汀、人工智能2 小时前
[特殊字符] 第57课:搜索旋转排序数组
数据结构·算法·数据库架构·图论·bfs·搜索旋转排序数组
倦王2 小时前
力扣日刷47
算法·leetcode·职场和发展
MicroTech20252 小时前
突破量子数据加载瓶颈,MLGO微算法科技推出面向大规模量子计算的分治态制备技术
科技·算法·量子计算