当前位置:网站首页>Three oj questions on leetcode
Three oj questions on leetcode
2022-07-31 04:52:00 【Qingfengyugu(「・ω・)「Hey】
目录
移除元素
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度.
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组.
元素的顺序可以改变.你不需要考虑数组中超出新长度后面的元素.
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/remove-element
解析

代码
int removeElement(int* nums, int numsSize, int val){
int src = 0;
int dst = 0;
while(src != numsSize)
{
if(nums[src] != val)
{
nums[dst] = nums[src];
++src;
++dst;
}
else
{
++src;
}
}
return dst;
}
删除有序数组中的重复项
给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素只出现一次 ,返回删除后数组的新长度.元素的 相对顺序 应该保持 一致 .
由于在某些语言中不能改变数组的长度,所以必须将结果放在数组nums的第一部分.更规范地说,如果在删除重复项之后有 k 个元素,那么 nums 的前 k 个元素应该保存最终结果.
将最终结果插入 nums 的前 k 个位置后返回 k .
不要使用额外的空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成.
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-array
解析

代码
int removeDuplicates(int* nums, int numsSize){
int src = 0;
int dst = 0;
while( src != numsSize)
{
if(nums[src] == nums[dst])
{
++src;
}
else
{
nums[++dst] = nums[src];
++src;
}
}
return dst+1;
}
合并两个有序数组
给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目.
请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列.
注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中.为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略.nums2 的长度为 n .
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/merge-sorted-array
解析

代码
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n){
int end1 = m-1;
int end2 = n-1;
int i = m+n-1;
while(end1 >= 0 && end2 >= 0)
{
if(nums1[end1] < nums2[end2])
{
nums1[i] = nums2[end2];
--i;
--end2;
}
else
{
nums1[i] = nums1[end1];
--i;
--end1;
}
}
while(end2 >=0)
{
nums1[i] = nums2[end2];
--i;
--end2;
}
}
边栏推荐
- Industry landing presents new progress | 2022 OpenAtom Global Open Source Summit OpenAtom OpenHarmony sub-forum was successfully held
- Solved (the latest version of selenium framework element positioning error) NameError: name 'By' is not defined
- ERP生产作业控制 金蝶
- Unity教程:URP渲染管线实战教程系列【1】
- Sql解析转换之JSqlParse完整介绍
- PWN ROP
- 三子棋的代码实现
- 【C语言进阶】文件操作(一)
- 【C语言】操作符详解
- [Cloud Native] DevOps (5): Integrating Harbor
猜你喜欢

【debug锦集】Expected input batch_size (1) to match target batch_size (0)

MATLAB/Simulink & & STM32CubeMX tool chain completes model-based design development (MBD) (three)

VScode+ESP32 quickly install ESP-IDF plugin

SOLVED: After accidentally uninstalling pip (two ways to manually install pip)

STM32HAL library modifies Hal_Delay to us-level delay

ERROR 2003 (HY000) Can‘t connect to MySQL server on ‘localhost3306‘ (10061)

Go语学习笔记 - 处理超时问题 - Context使用 | 从零开始Go语言

PWN ROP

矩池云快速安装torch-sparse、torch-geometric等包

Go language study notes - dealing with timeout problems - Context usage | Go language from scratch
随机推荐
MATLAB/Simulink & & STM32CubeMX tool chain completes model-based design development (MBD) (three)
C Implementation of Simple Network File Copy
Unity Fighter
MySQL忘记密码怎么办
PWN ROP
MySQL数据库备份
数字经济时代的开源数据库创新 | 2022开放原子全球开源峰会数据库分论坛圆满召开
城市内涝及桥洞隧道积水在线监测系统
[Linear Neural Network] softmax regression
【C语言进阶】文件操作(一)
PCL 计算点云坐标最值及其索引
BUG destroyer!!Practical debugging skills are super comprehensive
STM32HAL library modifies Hal_Delay to us-level delay
问题1:给你1-10的列表,实现列表输出,单数在左边,双数在右边。
DVWA靶场环境搭建
Duplicate entry ‘XXX‘ for key ‘XXX.PRIMARY‘解决方案。
prompt.ml/15中<svg>标签使用解释
Fusion Cloud Native, Empowering New Milestones | 2022 Open Atom Global Open Source Summit Cloud Native Sub-Forum Successfully Held
MySQL based operations
Gaussian distribution and its maximum likelihood estimation