当前位置: 首页 > news >正文

新疆建设工程信息网站天津最新消息今天

新疆建设工程信息网站,天津最新消息今天,一带一路网站建设,天猫网站做的比京东好去重删除有序数组中的重复项题目来自:https://leetcode.cn/problems/remove-duplicates-from-sorted-array/description/题目描述给你一个 升序排列 的数组 nums ,请你原地删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数…

去重

删除有序数组中的重复项

题目来自:https://leetcode.cn/problems/remove-duplicates-from-sorted-array/description/

题目描述

给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致
由于在某些语言中不能改变数组的长度,所以必须将结果放在数组nums的第一部分。更规范地说,如果在删除重复项之后有 k 个元素,那么 nums 的前 k 个元素应该保存最终结果。
将最终结果插入 nums 的前 k 个位置后返回 k 。
不要使用额外的空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

判断标准

系统会用下面的代码来测试你的题解:
int[] nums = [...]; // 输入数组 int[] expectedNums = [...]; // 长度正确的期望答案 int k = removeDuplicates(nums); // 调用 assert k == expectedNums.length; for (int i = 0; i < k; i++) { assert nums[i] == expectedNums[i]; }
如果所有断言都通过,那么您的题解将被 通过

题目示例

示例 :
输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。

题目思路

题目解法

int removeDuplicates(int* nums, int numsSize)
{if(numsSize == 0)return 0;int begin = 0,end = 1;int dst = 0;while(end < numsSize){if(nums[begin] == nums[end])end++;else{nums[dst] = nums[begin];begin = end;end++;dst++;}}nums[dst] = nums[begin];dst++;return dst;
}

合并

合并两个有序数组

题目来自:https://leetcode.cn/problems/merge-sorted-array/

题目描述

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。
请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。
注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n 。

题目示例

示例 1:
输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3 输出:[1,2,2,3,5,6] 解释:需要合并 [1,2,3] 和 [2,5,6] 。 合并结果是 [1,2,2,3,5,6] ,其中斜体加粗标注的为 nums1 中的元素。
示例 2:
输入:nums1 = [1], m = 1, nums2 = [], n = 0 输出:[1] 解释:需要合并 [1] 和 [] 。 合并结果是 [1] 。
示例 3:
输入:nums1 = [0], m = 0, nums2 = [1], n = 1 输出:[1] 解释:需要合并的数组是 [] 和 [1] 。 合并结果是 [1] 。 注意,因为 m = 0 ,所以 nums1 中没有元素。nums1 中仅存的 0 仅仅是为了确保合并结果可以顺利存放到 nums1 中。

题目思路

第一种情况

第二种情况

题目解法

void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n)
{int end = n + m - 1;int nums1End = m - 1;int nums2End = n - 1;while(nums1End >= 0 && nums2End >= 0){if(nums1[nums1End] > nums2[nums2End]){nums1[end--] = nums1[nums1End--];}else{nums1[end--] = nums2[nums2End--];}}while(nums2End >= 0){nums1[end--] = nums2[nums2End--];}
}

http://www.yidumall.com/news/83596.html

相关文章:

  • wordpress+仿站步骤seo优化一般包括哪些内容
  • 免注册个人网站制作推广如何做网上引流
  • crm管理系统的优缺点上海外贸网站seo
  • wordpress 无法选择数据库福州seo
  • wordpress apcseo快速排名利器
  • 做壁纸网站好谷歌seo技巧
  • 网站建设合约seo教程有什么
  • 做网站多少分辨率好免费python在线网站
  • wordpress注册显示密码错误天津seo优化
  • 流量多网站服务推广软文
  • 网站注册免费百度公司网站推广怎么做
  • vps网站目录是灰色的百度文库网页版
  • 如何在微信公众号添加wordpressseo关键词挖掘
  • 网站根目录是哪个文件夹2022百度seo优化工具
  • 长安网站建设详细教程企业网站建站模板
  • 考试源码网站wordpress网站权重查询
  • 海南网站建设公司长沙网站seo优化排名
  • 佳作哪个公司做网站比较好百度新闻首页
  • 现代建设公司网站个人网页制作教程
  • 做情诗网站百度竞价排名商业模式
  • 菜鸟如何做网站公众号怎么做文章推广
  • 福州建设局网站可以免费做网站推广的平台
  • 做网站的流程视频教程重庆seo博客
  • 机械做卖产品网站收录优美图片app
  • 图片在线制作生成器免费泰安seo网络公司
  • 网站建设市场拓展岗位关键词优化公司如何选择
  • 目字形布局结构的网站今日头条热搜榜前十名
  • 做5g网站广州网络推广
  • 做ppt模板网站电脑编程培训学校哪家好
  • 怎样做独立网站微信最好用的营销软件