【笔试】算法的暴力美学——牛客 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;
}
相关推荐
瞎折腾啥啊3 小时前
vcpkg与CMake
linux·c++·cmake·cmakelists
wljy13 小时前
牛客每日一题(2026.4.30) 整数域二分
c语言·c++·算法·蓝桥杯·二分
水蓝烟雨3 小时前
3335. 字符串转换后的长度 I
算法·leetcode
Dxy12393102163 小时前
HTML 如何使用 SVG 画曲线
前端·算法·html
westdata-Tm3 小时前
洛谷P1219 [USACO1.5] 八皇后 Checker Challenge
算法·深度优先·dfs
白夜11173 小时前
C++任务调度与状态机
开发语言·c++·笔记
南宫萧幕3 小时前
MATLAB/Simulink 从零打通:HEV 能量管理 GA 联合仿真保姆级建模指南
开发语言·算法·matlab·汽车·控制·pid
小雅痞3 小时前
[Java][Leetcode middle] 15. 三数之和
java·算法·leetcode
图码3 小时前
矩阵数据结构入门指南:声明、初始化与基本操作
运维·数据结构·线性代数·算法·矩阵
Navigator_Z4 小时前
LeetCode //C - 1030. Matrix Cells in Distance Order
c语言·算法·leetcode