当前位置:网站首页>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;
}
}
边栏推荐
猜你喜欢
The MySQL database installed configuration nanny level tutorial for 8.0.29 (for example) have hands
Doris学习笔记之监控
MATLAB/Simulink&&STM32CubeMX工具链完成基于模型的设计开发(MBD)(三)
View source and switch mirrors in two ways: npm and nrm
MySQL忘记密码怎么办
DVWA靶场环境搭建
【线性神经网络】softmax回归
EasyExcel的简单读取操作
数字经济时代的开源数据库创新 | 2022开放原子全球开源峰会数据库分论坛圆满召开
Reinforcement learning: from entry to pit to shit
随机推荐
SOLVED: After accidentally uninstalling pip (two ways to manually install pip)
Unity教程:URP渲染管线实战教程系列【1】
MySQL database must add, delete, search and modify operations (CRUD)
Heavyweight | The Open Atomic School Source Line activity was officially launched
Sql解析转换之JSqlParse完整介绍
DVWA安装教程(懂你的不懂·详细)
强化学习:从入门到入坑再到拉屎
open failed: EACCES (Permission denied)
MySQL fuzzy query can use INSTR instead of LIKE
两个地址池r2负责管地址池r1负责管dhcp中继
PWN ROP
WPF WPF 】 【 the depth resolution of the template
Solved (the latest version of selenium framework element positioning error) NameError: name 'By' is not defined
ERROR 2003 (HY000) Can‘t connect to MySQL server on ‘localhost3306‘ (10061)解决办法
Fusion Cloud Native, Empowering New Milestones | 2022 Open Atom Global Open Source Summit Cloud Native Sub-Forum Successfully Held
开源汇智创未来 | 2022开放原子全球开源峰会OpenAtom openEuler分论坛圆满召开
Explanation of
MySQL 8.0.30 GA
【R语言】【3】apply,tapply,lapply,sapply,mapply与par函数相关参数
MySQL数据库安装配置保姆级教程(以8.0.29为例)有手就行