排序算法刷题【leetcode:04题,寻找两个正序数组的中位数。leetcode:219题,存在重复的元素 】

本文主要是介绍排序算法刷题【leetcode:04题,寻找两个正序数组的中位数。leetcode:219题,存在重复的元素 】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码如下所示:

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;/* leetcode04题:寻找两个正序数组的中位数 */
class Solution {
public:double findMedianSortedArrays(vector<int>& nums1, vector<int>& nums2) {int L1 = nums1.size(), L2 = nums2.size(), p1 = 0, p2 = 0, p3 = 0;vector<int> nums(L1 + L2);while (p1 < L1 || p2 < L2){if (p1 == L1 || p2 != L2 && (nums1[p1] >= nums2[p2])){nums[p3++] = nums2[p2++];}else {nums[p3++] = nums1[p1++];}}p1 = (L1 + L2) / 2, p2 = (L1 + L2) / 2;if ((L1 + L2) % 2 == 0) p1--;double ret = (nums[p1] + nums[p2]) / 2.0;return ret;}
};void test()
{vector<int> v1, v2;v1.push_back(1);v1.push_back(3);v2.push_back(2);Solution s1;double ret = s1.findMedianSortedArrays(v1, v2);cout << "ret:" << ret;
}/* leetcode219题:存在重复的元素 */
class Solution {
public:bool containsNearbyDuplicate(vector<int>& nums, int k) {vector<int> index;for (int i = 0; i < nums.size(); i++) index.push_back(i);sort(index.begin(), index.end(), [&](int i, int j)->bool {if (nums[i] != nums[j]) return nums[i] < nums[j];   //数组元素不相等,按照数组元素的大小排序return i < j; });   //数组元素相等按照数组下标从小到达排序for (int i = 1; i < nums.size(); i++)     //排序之后,数组相邻元素肯定挨边{if (nums[index[i - 1]] != nums[index[i]]) continue;if (index[i] - index[i - 1] <= k) return true;}return false;}
};void test()
{vector<int> arry;for (int i = 1; i < 4; i++)  arry.push_back(i);for (int i = 1; i < 4; i++)  arry.push_back(i);Solution s1;s1.containsNearbyDuplicate(arry, 2);}int main()
{test();return 0;
}

这篇关于排序算法刷题【leetcode:04题,寻找两个正序数组的中位数。leetcode:219题,存在重复的元素 】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis