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

快速做网站哪家好营销软件商城

快速做网站哪家好,营销软件商城,网站策划书主题,做网站的表情包本篇博客讲解LeetCode热题100道普通数组篇中的五道题 第五道:缺失的第一个正数(困难) 第五道:缺失的第一个正数(困难) 方法一:将数组视为哈希表 class Solution {public int firstMissingPosi…

本篇博客讲解LeetCode热题100道普通数组篇中的五道题

第五道:缺失的第一个正数(困难)

第五道:缺失的第一个正数(困难)

方法一:将数组视为哈希表 

class Solution {public int firstMissingPositive(int[] nums) {int n = nums.length;for (int i = 0; i < n; ++i) {if (nums[i] <= 0) {nums[i] = n + 1;}}for (int i = 0; i < n; ++i) {int num = Math.abs(nums[i]);if (num <= n) {nums[num - 1] = -Math.abs(nums[num - 1]);}}for (int i = 0; i < n; ++i) {if (nums[i] > 0) {return i + 1;}}return n + 1;}
}

1.将负数,0,替换为n+1变成无效数字,因为我们只关心[1,n]的正数。

2.标记已存在的正整数,对于每一个元素 `nums[i]`,我们用它的绝对值 `num` 来表示。如果num是一个有效的数字,也就是num<=n。那么将数组中索引num-1的元素下标记为负数。这一步结束后,数组中所有出现过的正整数对应的索引位置都会被标记为负数。

3.查找第一个未被标记的位置。查找第一个仍然为正数的元素。此时返回i+1。

4.如果没有找到返回n+1

复杂度分析

  • 时间复杂度:O(N),其中 N 是数组的长度。

  • 空间复杂度:O(1)。

 

方法二:置换(恢复)

class Solution {public int firstMissingPositive(int[] nums) {int n = nums.length;for (int i = 0; i < n; ++i) {while (nums[i] > 0 && nums[i] <= n && nums[nums[i] - 1] != nums[i]) {int temp = nums[nums[i] - 1];nums[nums[i] - 1] = nums[i];nums[i] = temp;}}for (int i = 0; i < n; ++i) {if (nums[i] != i + 1) {return i + 1;}}return n + 1;}
}

除了打标记以外,我们还可以使用置换的方法,将给定的数组「恢复」成下面的形式: 

  • 遍历数组:对于每个元素,将其放置在正确的位置上,即把数字 nums[i] 放在索引 nums[i] - 1 的位置上。通过不断交换,确保每个正整数 k 出现在索引 k-1 的位置上。
  • 检查数组:再遍历一次数组,找到第一个位置 i 使得 nums[i] != i + 1,即第一个缺失的正整数是 i + 1
  • 返回结果:如果所有位置都满足 nums[i] == i + 1,则返回 n + 1,即数组长度加一的值。

复杂度分析

  • 时间复杂度:O(N),其中 N 是数组的长度。

  • 空间复杂度:O(1)。

http://www.khdw.cn/news/48991.html

相关文章:

  • 国外音乐网站设计站内推广有哪些具体方式
  • 广州有网站建设学校百度股市行情上证指数
  • 网站建设公司运营计划seo的优缺点
  • 什么网站可以做效果图百度账号管理中心
  • 怎样登录韵网网站百度云盘官网登录入口
  • 可信网站身份验证深圳推广公司排行榜
  • 荥阳做网站app开发软件
  • 有哪些网站做生鲜到家免费seo快速排名工具
  • 电子配件 技术支持 东莞网站建设产品免费推广网站有哪些
  • 电影网站建设教程百度推广关键词查询
  • 网站制作滚动图片怎么做seo推广的公司
  • 怎样做企业网站建设网络运营是做什么的
  • 广州分享网站建设高报师培训机构排名
  • 网站首页轮播图怎么做的外贸找客户有什么网站
  • 成都网站建设优化推广互联网的推广
  • 做招聘网站怎么样seo如何优化图片
  • 网络运营者开展经营和服务活动必须什么承担社会责任新手做seo怎么做
  • 网站建设预付款比例今天的热点新闻
  • 网站开发谢辞西安快速排名优化
  • 公司请人做的网站打不开百度关键词搜索热度查询
  • 衡水企业网站建设友情链接系统
  • wordpress 新闻模板信息流优化师简历模板
  • 公积金网站怎么做增员58百度搜索引擎
  • 可以免费做简历的网站优化大师班级优化大师
  • 如何进行电子商务网站建设全国各城市疫情搜索高峰进度
  • 国内外政府网站建设借鉴seo交流中心
  • 免费建设网站长沙seo推广公司
  • 附近卖建筑模板市场威海seo优化公司
  • 班级设计网站建设百度地址如何设置门店地址
  • 如何提升网站百度权重品牌营销策略研究