当前位置: 首页 > article >正文

牛客(除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;
}


http://www.kler.cn/news/294969.html

相关文章:

  • 设计模式 19 观察者模式
  • 【AIGC】AI编程工具合集及其特点介绍
  • 1-18 平滑处理——高斯滤波 opencv树莓派4B 入门系列笔记
  • 【LabVIEW学习篇 - 17】:人机交互界面设计01
  • 以后写代码都是AI自动写了,Cursor+Claude-3.5-Sonnet,Karpathy 点赞的 AI 代码神器。如何使用详细教程
  • 解决异步任务上下文丢失问题
  • 【Python】6.基础语法(6)文件
  • DataLoader使用
  • [数据集][目标检测]电动车头盔佩戴检测数据集VOC+YOLO格式4235张5类别
  • 计算机网络与Internet应用
  • OpenCV与Matplotlib:灰度图像
  • 漫谈设计模式 [20]:解释器模式
  • 实战项目-快速实战-springboot dataway
  • linux 检查cpu 内存命令
  • Flutter基本组件Text使用
  • 嵌入式面试刷题
  • 商城系统的数据库
  • 电脑录屏杂音太大怎么办 电脑录屏杂音去除办法有哪些 解决录屏电流声等问题技巧与工具推荐
  • 如何选择国内大带宽服务器租用?
  • ❤《实战纪录片 1 》原生开发小程序中遇到的问题和解决方案
  • 一个vue重新回顾,好多年前写的
  • 常见的排序
  • Leetcode 152. 乘积最大子数组(Medium)
  • 通信工程学习:什么是ARQ自动重传请求
  • 【计算机视觉】语义分割输入图像尺寸
  • 快速傅里叶变换(FFT)及其在多项式乘法中的应用 —— 深入分析与 Python 实现
  • android AccessibilityService合法合规采集大众点评app商店商品详情(2024-09-02)
  • 【Qt笔记】QListWidget控件详解
  • 经济管理专业数据库介绍
  • 算法学习:模拟