JZ40 最小的K个数

news/2024/9/18 12:30:37/ 标签: 算法, 数据结构, c++, 剑指offer

最小的K个数_牛客题霸_牛客网

描述

给定一个长度为 n 的可能有重复值的数组,找出其中不去重的最小的 k 个数。例如数组元素是4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4(任意顺序皆可)。

数据范围:0≤k,n≤100000≤k,n≤10000,数组中每个数的大小0≤val≤10000≤val≤1000

要求:空间复杂度 O(n)O(n) ,时间复杂度 O(nlogk)O(nlogk)

示例1

输入:[4,5,1,6,2,7,3,8],4        返回值:[1,2,3,4]

说明:返回最小的4个数即可,返回[1,3,2,4]也可以

解法:

1.分治:快排思想,比较K和分治后pos的大小,如果相等,说明找到了,pos前面的数就是结果.,题目要求还需要对pos前的元素进行排序。

2.维护一个K个节点的大根堆,对于[k,n-1]之间的元素,每次拿堆顶元素和当前元素对比,交

换比堆顶元素小的,重新调整。

3.书中解题,多重哈希表,哈希表从大到小排序,依次往哈希表插入k个元素,如果哈希表有了k个元素,往后每遍历一个值,把0号元素(最大值)和当前元素进行对比,0号元素比进来的元素小,删除0号元素,插入当前元素。

1.分治

#include <any>
#include <functional>
#include <iterator>
#include <utility>
#include <vector>
class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param input int整型vector * @param k int整型 * @return int整型vector*/// 分治int partition(vector<int>& input, int left, int right, int k ){int i = left, j = left;for(; i < right; ++i){if(input[i] < input[right]){swap(input[i], input[j]);++j;}}swap(input[j],input[right]);if(j == k - 1) return j;else if(j > k - 1) return partition(input, left, j-1, k);else if(j < k - 1) return partition(input, j+1, right, k);return -1;}vector<int> GetLeastNumbers_Solution(vector<int>& input, int k) {// write code hereif(!k || input.empty()) return vector<int>{};vector<int> res;// 1.分治int res_pos = partition(input, 0, input.size() - 1, k);copy_n(input.begin(), k,back_inserter(res));return res;}};

2.K个节点的大根堆

#include <any>
#include <functional>
#include <iterator>
#include <utility>
#include <vector>
class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param input int整型vector * @param k int整型 * @return int整型vector*/vector<int> GetLeastNumbers_Solution(vector<int>& input, int k) {// write code hereif(!k || input.empty()) return vector<int>{};vector<int> res;// 2.K个结点的大根堆int nums_size = input.size();for(int idx = k / 2 - 1; idx >=0 ; --idx){adjustMaxHeap(input, idx, k);} //维护K个结点的大根堆for(int idx = k; idx < nums_size; ++idx){if(input[0] > input[idx]){ //把K后面的值依次和堆顶比较, 如果堆顶元素>新插入的元素swap(input[0], input[idx]);adjustMaxHeap(input, 0, k); //调整为大根堆}}copy_n(input.begin(), k, back_inserter(res));sort(res.begin(), res.end()); return res;}//维护一个k个结点的大根堆void adjustMaxHeap(vector<int>&input, int pos, int len){int dad = pos;int son =  2*dad +1;while(son < len){if(son +1 < len && input[son] < input[son+1]){++son;}if(input[son] > input[dad] ){swap(input[son],input[dad]);dad = son;son = 2 * dad + 1;}else break;}}};

3.multi_set

#include <any>
#include <functional>
#include <iterator>
#include <utility>
#include <vector>
class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param input int整型vector * @param k int整型 * @return int整型vector*/vector<int> GetLeastNumbers_Solution(vector<int>& input, int k) {// write code hereif(!k || input.empty()) return vector<int>{};vector<int> res;//书中解题3,多重哈希表,哈希表从大到小排序,依次往哈希表插入k个元素,//如果哈希表有了k个元素,往后每遍历一个值,把0号元素和当前元素进行对比,0号元素比进来的元素小,删除0号元素,插入当前元素。multiset<int, greater<int>> hash_table;for(int idx = 0; idx < input.size(); ++idx){if(hash_table.size() < k){ hash_table.insert(input[idx]);}else{if(*hash_table.begin() > input[idx]){hash_table.erase(hash_table.begin());hash_table.insert(input[idx]);}}}// //从小到大插入结果容器vectorcopy(hash_table.rbegin(),hash_table.rend(), back_inserter(res));return res;}};


http://www.ppmy.cn/news/1516028.html

相关文章

微服务接口框架

微服务的接口框架是构建和管理微服务通信的核心工具&#xff0c;用于定义、开发、发布、和维护服务之间的接口。微服务架构的核心思想是将单一应用程序拆分为多个独立的服务&#xff0c;这些服务通过接口&#xff08;通常是 API&#xff09;进行通信。因此&#xff0c;选择和使…

数据库性能诊断利器 聚好看DBdoctor亮相中国数据库技术大会

2024年8月22-24日&#xff0c;备受瞩目的第15届中国数据库技术大会&#xff08;DTCC2024&#xff09;于北京隆总召开。数字化创新浪潮汹涌澎湃&#xff0c;数据库作为信息技术的核心基础设施&#xff0c;正以前所未用的速度推动各行各业的智能化升级。作为在数据库技术领域率先…

中间件(22) : nginx通过http接口获取代理目标地址(win)|nginx自定义负载均衡算法

参考 : Nginx12 openresty使用lua-resty-http模块 - 金天黑日 - 博客园 (cnblogs.com) windows openresty 死磕&#xff1a;安装和启动脚本 - 疯狂创客圈 - 博客园 (cnblogs.com) https://blog.csdn.net/wwppp987/article/details/122803662 1.下载软件包 1.1.openresty Ope…

探索Git:分布式版本控制系统的力量(二)

&#x1f600;前言 本篇博文是关于分布式版本控制系统Git的一些基本介绍&#xff0c;希望你能够喜欢 &#x1f3e0;个人主页&#xff1a;晨犀主页 &#x1f9d1;个人简介&#xff1a;大家好&#xff0c;我是晨犀&#xff0c;希望我的文章可以帮助到大家&#xff0c;您的满意是我…

【STM32】驱动OLED屏

其实我没买OLED屏哈哈哈&#xff0c;这个只是学习了&#xff0c;没机会实践。 大部分图片来源&#xff1a;正点原子HAL库课程 专栏目录&#xff1a;记录自己的嵌入式学习之路-CSDN博客 目录 1 显示原理 2 读写方式&#xff1a;8080并口 2.1 支持的指令类型 2.2 …

亦菲喊你来学机器学习(12) --随机森林

文章目录 随机森林基本原理随机森林特点优点缺点 构建模型模型参数训练模型测试模型绘制重要特征 注意事项 总结 随机森林 随机森林&#xff08;Random Forest&#xff09;是一种集成学习方法&#xff0c;属于决策树模型的扩展。它通过构建多个决策树并将它们的预测结果进行汇…

英国政府停止使用人工智能

你是否注意到&#xff0c;每家公司都声称他们拥有一些新发现的人工智能技术&#xff0c;这些技术显然使他们更胜一筹&#xff0c;但这些人工智能却完全是空洞的&#xff0c;令人失望&#xff1f;我也是&#xff0c;这也是我对这项技术如此怀疑的一半原因。但在过去几年里&#…

Golang | Leetcode Golang题解之第374题猜数字大小

题目&#xff1a; 题解&#xff1a; func guessNumber(n int) int {return sort.Search(n, func(x int) bool { return guess(x) < 0 }) }

K8S对接Ceph分部署存储

文章目录 一、Ceph理论知识1、Ceph简介2、Ceph分布式存储的优点3、Ceph核心组件 二、部署Ceph高可用集群1、服务器环境信息2、部署前环境准备工作3、部署Ceph监控服务Monitor4、激活Ceph存储服务OSD 三、K8S对接Ceph存储1、K8S对接Ceph RBD实现数据持久化2、基于Ceph RBD生成PV…

在编程学习的道路上,面对Bug和复杂算法时,我们常常会感到挫折和困惑。以下是一些克服这些挑战的有效方法:

在编程学习的道路上&#xff0c;面对Bug和复杂算法时&#xff0c;我们常常会感到挫折和困惑。以下是一些克服这些挑战的有效方法&#xff1a; 系统化问题解决&#xff1a; 遇到Bug时&#xff0c;首先要从整体入手&#xff0c;系统地分析问题。例如&#xff0c;可以通过逐步调试…

2024年Intellij IDEA快捷键总结

目录 编辑与格式化&#xff1a; 导航与跳转&#xff1a; 重构&#xff1a; 查找与替换&#xff1a; 调试 其他常用&#xff1a; 使用快捷键的好处&#xff1a; 快捷键功能描述 编辑与格式化&#xff1a; CtrlX删除当前行或选中的文本CtrlD复制当前行或选中的文本到下一行…

iPhone13手机照片被误删,有什么方法可以恢复吗?

在日常使用手机时&#xff0c;我们可能因为误操作、手机崩溃、或者其他原因&#xff0c;导致iPhone13手机中的照片丢失。遇到这种情况&#xff0c;手机误删照片如何恢复&#xff1f;在本文中&#xff0c;我们将分享3个妙招&#xff0c;帮助您恢复iPhone13上误删的照片。 一、通…

Flask restful 前后端分离和 restful 定义

Flask restful 前后端分离和 restful 定义 前后端分离RESTful API总结在Web开发中,前后端分离(Frontend and Backend Separation)和RESTful API(Representational State Transfer 应用程序接口)是两个重要的概念,特别是在构建大型或复杂的Web应用程序时。Flask作为一个轻…

解锁C#性能监控:内置性能计数器全解析

标题&#xff1a;解锁C#性能监控&#xff1a;内置性能计数器全解析 摘要 性能计数器是衡量和监控应用程序性能的重要工具。在C#中&#xff0c;.NET框架提供了一套完整的性能计数器类库&#xff0c;使得开发者能够轻松地收集和分析应用程序的运行时数据。本文将详细介绍如何在…

【第一章概述—计算机中的数制】非十进制数到十进制数的转换,八进制转十进制,16进制转十进制。十进制转8进制,十进制转16进制

将非十进制数转换为十进制数或将十进制数转换为其他进制数&#xff0c;具体步骤如下&#xff1a; 八进制&#xff08;Octal&#xff09;转换为十进制&#xff08;Decimal&#xff09; 八进制转十进制&#xff1a; 每个八进制位乘以其对应的权重&#xff1a; 从右到左&#x…

Python爬虫—常用的网络爬虫工具推荐

以下列举几个常用的网络爬虫工具 1. 八爪鱼&#xff08;Bazhuayu&#xff09; 简介&#xff1a; 八爪鱼是一款面向非技术用户的桌面端爬虫软件&#xff0c;以其可视化操作和强大的模板库而受到青睐。它支持从各种网站上抓取数据&#xff0c;包括文本、图片、文档等&#xff…

MySQL对JSON数据类型的处理

MySQL从5.7版本开始提供了对JSON数据类型的支持&#xff0c;‌使得MySQL能够直接存储和管理JSON格式的数据。‌这使得在数据库中处理JSON数据变得更为方便和高效。‌以下是一些常用的处理JSON数据的函数和操作&#xff1a;‌ 1.‌创建JSON列 CREATE TABLE my_table (id INT A…

uniapp-:class内使用函数报错及解决方法

在开发时&#xff0c;需要根据状态动态的去渲染颜色&#xff0c;这个时候就用到了 :class :class"hColor(2,item, index)" 在vue内开发时&#xff0c;此代码片段可以正常使用 在uniapp内开发时&#xff0c;相同代码报错&#xff0c;因为在uniapp内 :class不支持直接…

优化学习管理:Moodle和ONLYOFFICE文档编辑器的完美结合

目录 前言 一、什么是 Moodle 1、简单快速插入表单字段 3、免费表单模板库 4、开启无缝协作 三、在Moodle中集成ONLYOFFICE文档 四、在Moodle安装使用ONLYOFFICE 1、下载安装 2、配置服务器 3、在Moodle中使用ONLYOFFICE 文档活动 五、未来展望 写在最后 前言 在当今教育科技飞…

启动kafka

启动 kafka 启动 kafka 使用 zookeeper # 启动 zookeeper ./zookeeper-server-start.sh ../config/zookeeper.properties & # 启动 kafka ./kafka-server-start.sh ../config/server.properties &# 关闭 kafka ./kafka-server-stop.sh ../config/server.properties# …