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

局域网做网站网站seo优化公司

局域网做网站,网站seo优化公司,东莞市研发网站建设品牌,专业的网站建设设计给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。 请你设计并实现时间复杂度为 O(n) 的算法解决此问题。 示例 1: 输入:nums [100,4,200,1,3,2] 输出:4 …

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:

输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。

On 算法 找 最长连续序列,这个序列并不像最长上升序列一样需要保证下标的递增,并且 On 的 算法,只能 遍历一遍数组就要求给出答案了,一开始打算用 优先队列去保证数字的有序性。后面看到hash 也能做,这个就是真 O1了。用空间换时间是常见降低时间复杂度的手段。

这道题可以把所有的数字都放到 HashSet中,然后通过遍历数组,找到每段连续序列中的第一个数字 n,这个第一个数字 n 的条件就是 n - 1 不在 HashSet中。然后不断找后面的连续数字,直到没有位置。统计这样的所有连续序列,找出最大长度。

class Solution {public int longestConsecutive(int[] nums) {if(nums.length == 0) {return 0;}Set<Integer> set = new HashSet<>();Map<Integer, Integer> ll = new HashMap<>();for(int num : nums) {set.add(num);}int ans = 1;for(Integer num : set) {if(!set.contains(num - 1)) {int cur = num;while(set.contains(cur + 1)) {cur = cur + 1;}ans = Math.max(ans, cur - num + 1);} else {continue;}}return ans;}
}
http://www.hkea.cn/news/38295/

相关文章:

  • 建设的网站首页微信怎么做推广
  • 建设网站导航百度信息流推广和搜索推广
  • 深圳室内设计公司招聘信息流广告优化
  • 旅游网站首页四种营销模式
  • 负责网站建设如何在百度发广告推广
  • 联通的网站是谁做的营销的主要目的有哪些
  • 衡阳微信网站地推的方法和技巧
  • 南阳做网站公司哪家好自动发外链工具
  • 潍坊网站制作最低价格网络营销案例有哪些
  • 做网站有谁做谷歌seo视频教程
  • 资深的网站推广完美日记网络营销策划书
  • 90设计网站免费素材网站seo培训
  • 整形美容网站源码上海seo优化bwyseo
  • 武威市住房和建设局网站百度app下载安装普通下载
  • 网站物理结构天津百度推广排名
  • 美容平台网站建设百度指数查询移动版
  • 工程公司手机网站建立网站怎么搞
  • 做网站软件wd惠州seo外包
  • 聊城做网站seo关键词分类
  • 网站做公司女生学网络营销这个专业好吗
  • 网络运营主要工作内容seo教程自学入门教材
  • 用其他商标在自己网站做宣传百度云网盘资源分享网站
  • 对商家而言网站建设的好处淘宝关键词查询工具哪个好
  • 做简单网站代码关键词推广价格
  • 做品牌折扣的网站百度推广的五大优势
  • 南宁比较有好的网站制作公司百度推广后台登录页面
  • 长沙企业网站排名优化windows优化大师和360哪个好
  • 珠海网站开发维护科技公司免费的网络推广渠道有哪些
  • wp建站系统微信营销管理软件
  • 本地打开WordPress慢百度seo优化分析