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

阿里巴巴做网站吗上海seo怎么优化

阿里巴巴做网站吗,上海seo怎么优化,企业网站seo平台,正规兼职做任务赚钱网站本篇博客讲解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.hrbkazy.com/news/16618.html

相关文章:

  • 网站建设交流论坛魔贝课凡seo
  • 怎样用模板做网站百搜网络科技有限公司
  • 有了实名制域名怎么做网站百度seo官网
  • wap网站设计规范百度付费推广有几种方式
  • 上海网站建设公司推荐适合40岁女人的培训班
  • 餐饮网站开发软文自动发布软件
  • asp.net实用网站开发doc百度推广找谁
  • 时时彩网站制作今日国内新闻热点
  • 群辉域名登录wordpressseo网站建设优化什么意思
  • 网站备案个人可以做吗免费推广软件下载
  • 58同城会员推广靠谱吗首页优化公司
  • 网页托管网站搜索量用什么工具查询
  • 百度站长平台验证网站长春seo排名优化
  • 太原软件行业站长seo查询
  • 视频素材网站推荐公司做网站一般多少钱
  • 用dede做网站后台网站建设与维护
  • 网站建设方案汇报搜索引擎优化心得体会
  • 免费自己做网站手机软件网络营销师培训费用是多少
  • 长春专业做网站的公司排名李飞seo
  • 商城网站建设分为几块大连网站排名推广
  • wordpress获取当前目录父目录id南昌seo优化公司
  • 大兴做网站网店网络营销与推广策划书
  • 网络网站建设推广开发网站
  • 重庆网站建设吧百度快速排名 搜
  • 策划专业网站广西百度seo
  • 湘潭做网站 z磐石网络竞价推广和信息流推广
  • 在手机上创建网站吗株洲做网站
  • 网上如何做网站宁波免费建站seo排名
  • 网站建设什么公司专业品牌推广方案模板
  • 四川省人民政府副秘长有哪些中国seo关键词优化工具