当前位置:网站首页>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;
}
}
边栏推荐
- Unity打灵狐者
- MySQL忘记密码怎么办
- three.js 制作3D相册
- 开源汇智创未来 | 2022开放原子全球开源峰会OpenAtom openEuler分论坛圆满召开
- Heavyweight | The Open Atomic School Source Line activity was officially launched
- 【debug锦集】Expected input batch_size (1) to match target batch_size (0)
- Open Source Smart Future | 2022 OpenAtom Global Open Source Summit OpenAtom openEuler sub-forum was successfully held
- Reinforcement learning: from entry to pit to shit
- unity2d小游戏
- Unity资源管理系列:Unity 框架如何做好资源管理
猜你喜欢
ERROR 2003 (HY000) Can't connect to MySQL server on 'localhost3306' (10061)Solution
MATLAB/Simulink&&STM32CubeMX工具链完成基于模型的设计开发(MBD)(三)
Industry landing presents new progress | 2022 OpenAtom Global Open Source Summit OpenAtom OpenHarmony sub-forum was successfully held
Unity资源管理系列:Unity 框架如何做好资源管理
Error EPERM operation not permitted, mkdir 'Dsoftwarenodejsnode_cache_cacach Two solutions
mysql数据库安装(详细)
MySQL数据库增删改查(基础操作命令详解)
【线性神经网络】softmax回归
[Cloud Native] DevOps (5): Integrating Harbor
ERP Production Operation Control Kingdee
随机推荐
扫雷游戏(c语言写)
View source and switch mirrors in two ways: npm and nrm
DVWA安装教程(懂你的不懂·详细)
exsl文件预览,word文件预览网页方法
从零开始,一镜到底,纯净系统搭建除草机(Grasscutter)
Unity shader forge和自带的shader graph,有哪些优缺点?
MATLAB/Simulink&&STM32CubeMX工具链完成基于模型的设计开发(MBD)(三)
pom文件成橘红色未加载的解决方案
Lua,ILRuntime, HybridCLR(wolong)/huatuo hot update comparative analysis
sql语句-如何以一个表中的数据为条件据查询另一个表中的数据
ERP Production Operation Control Kingdee
Create componentized development based on ILRuntime hot update
简易网络文件拷贝的C实现
VScode+ESP32快速安装ESP-IDF插件
Recursive implementation of the Tower of Hanoi problem
Duplicate entry ‘XXX‘ for key ‘XXX.PRIMARY‘解决方案。
Sql解析转换之JSqlParse完整介绍
MySQL开窗函数
Unity资源管理系列:Unity 框架如何做好资源管理
【py脚本】批量二值化处理图像