[leetcode215][c++实现]数组中的第K个最大元素

2024-01-08 12:38

本文主要是介绍[leetcode215][c++实现]数组中的第K个最大元素,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

记录下面试高频题,数组中的第K个最大元素。

这里记录用最大堆的解法,思路应为:构建一个最大堆,弹出堆顶元素,然后最大堆会自动维护,重复k次过程,就可以得到第K大的元素。

时间复杂度分析:构建最大堆:O(n),删除k个:O(klogn)。

首先记录一版调用api的代码

#include <iostream>
#include <string>
#include <set>
#include <cmath>
#include <vector>
#include <algorithm>
#include <queue>
using namespace std;
//string a max length string
void print_vec(vector<int> num){for(auto i:num)cout << i << " " ;cout << endl;
}
int main(int argc, const char * argv[]) {vector<int> input_num{7,8,4,24,12,53}; //inputprint_vec(input_num); //printint k;cin >> k;cout << "需要弹出第K大的元素:" << endl;make_heap(input_num.begin(), input_num.end(), less<int>()); //build a maxHeapwhile(k--){pop_heap(input_num.begin(), input_num.end(), less<int>()); //delete the top nodeif(k!=0){input_num.pop_back(); // pop the num in the vector}else{cout << "第k大的数:" << input_num.back() << endl;input_num.pop_back();}}print_vec(input_num);return 0;
}

首先,make_heap用来构建一个最大堆,pop_heap用来删除堆顶的节点,此时节点会被放在vector容器的末尾,用pop_back()彻底删除此节点。

下面记录一下手写堆api的代码。

void print_vec(vector<int> num){for(auto i:num)cout << i << " " ;cout << endl;
}
void check_maxHeap(vector<int> &num,int i){int child_left = i*2+1;int child_right = (i+1)*2;int largest_index = i;if(child_left<num.size() && num[largest_index]<num[child_left]){largest_index = child_left;}if(child_right<num.size() && num[largest_index]<num[child_right]){largest_index = child_right;}if (largest_index!=i) {swap(num[largest_index], num[i]);check_maxHeap(num, largest_index);}
}
void init_maxHeap(vector<int> &num){for(int i=num.size()/2;i>0;i--){check_maxHeap(num, i);}
}
void pop_heap(vector<int> &num){swap(num[0],num[num.size()-1]);num.pop_back();check_maxHeap(num, 0);
}int main(int argc, const char * argv[]) {vector<int> input_num{7,8,4,24,12,53};print_vec(input_num);int k;cin >> k;cout << "需要弹出第K大的元素:" << endl;init_maxHeap(input_num);while(k--){if(k!=0){pop_heap(input_num);}else{cout << "第k大的数:" << input_num.back() << endl;pop_heap(input_num);}}print_vec(input_num);return 0;
}

从上到下调整节点,当遇到一个非叶子节点的时候,检查孩子节点与其的大小关系(check_maxheap函数),如果这时需要交换节点,则需要递归检查其交换的子节点(是否还保持平衡)。

每次删除堆顶元素的时候,将末尾的节点与其交换,在用vector来删除末尾的元素,同时检查平衡。

参考资料:https://leetcode-cn.com/problems/kth-largest-element-in-an-array/solution/shu-zu-zhong-de-di-kge-zui-da-yuan-su-by-leetcode-/

这篇关于[leetcode215][c++实现]数组中的第K个最大元素的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/583487

相关文章

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构