排序算法刷题【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

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

Redis 多规则限流和防重复提交方案实现小结

《Redis多规则限流和防重复提交方案实现小结》本文主要介绍了Redis多规则限流和防重复提交方案实现小结,包括使用String结构和Zset结构来记录用户IP的访问次数,具有一定的参考价值,感兴趣... 目录一:使用 String 结构记录固定时间段内某用户 IP 访问某接口的次数二:使用 Zset 进行

Spring Boot 整合 ShedLock 处理定时任务重复执行的问题小结

《SpringBoot整合ShedLock处理定时任务重复执行的问题小结》ShedLock是解决分布式系统中定时任务重复执行问题的Java库,通过在数据库中加锁,确保只有一个节点在指定时间执行... 目录前言什么是 ShedLock?ShedLock 的工作原理:定时任务重复执行China编程的问题使用 Shed

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常