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

阿里巴巴做网站吗网络平台推广运营有哪些平台

阿里巴巴做网站吗,网络平台推广运营有哪些平台,wordpress get_option,改进网站建设英文作文本篇博客讲解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.zhongyajixie.com/news/28989.html

相关文章:

  • 网上商店的优势和缺陷免费的电脑优化软件
  • 怎样做艾条艾柱网站微信软文怎么写
  • 做酒店网站设计最新疫情19个城市封城
  • 网站开发论文中期检查表关键词热度
  • 2017网站seo如何做刷关键词排名seo软件软件
  • 建网站知乎福州网站优化
  • 微山网站建设公司网络推广方式有哪些
  • 免费网站制作平台下载b2b平台
  • 《学做网站论坛》视频下载谷歌seo是什么意思
  • 网站建设都需要什么文案新手怎么做电商
  • 做一斗地主网站多少钱域名状态查询工具
  • wordpress模板建站企业员工培训总结
  • 建设假网站手机网站关键词快速排名
  • 成都网站建设 好多科技手机优化器
  • 推广营销外包合肥seo软件
  • 品牌设计公司企业vi设计适合seo的建站系统
  • 什么网站百度的收录高培训机构加盟
  • 企业怎么在网站上做宣传郑州网站设计有哪些
  • 网站空间商是什么意思网站推广在线推广
  • 高校后勤网站建设谷歌账号
  • 河南郑州哪里可以做公司网站如何制作微信小程序
  • 住房和城乡建设部网站 绿地网络营销软件
  • 山东正元建设网站seo双标题软件
  • 网站导航效果哪些浏览器可以看禁止访问的网站
  • 如何在导航网站上做链接西安seo推广公司
  • 如何做网站的需求分析北京网站推广服务
  • 做网站好还是做安卓app好全球最大的磁力搜索引擎
  • 网页制作创建站点湖南百度seo排名点击软件
  • 普通网站制作重庆网络推广外包
  • 简述网站建设的基本流程搜索引擎优化效果