书籍数组中的最长连续序列(4)0716

题目
给定无序数组arr,返回其中最长的连续序列的长度。

一些定义:

数组

子数组: 一个或连续多个数组中的元素组成一个子数组。子数组最少包含一个元素。

对于大小为n的数组,有n*(n+1)/2个非空子数组。

子序列:子序列就是在原来序列中找出一部分组成的序列,子序列不一定来连续,相对位置还是不变。但是,在数学中,某个序列的子序列是从最初序列通过去除某些元素单补破坏余下元素的相对位置(在前或在后)而形成的新序列。

对于大小n的序列,总共可以有(2n次幂 -1)个非空子序列。

1.生成哈希表HashMap<Integer,Integer> map,key代表遍历过的某个数,value代表key这个数所在的最长连续序列的长度。同时map还可以表示arr中的一个数之前是否出现过。

2.从左到右遍历arr,假设遍历到arr[i]。如果arr[i]之前出现过,直接遍历下一个数,只处理之前没出现过的arr[i]。首先在map中加入记录(arr[i],1),代表目前arr[i]单独作为一个连续序列。然后看map中是否含有arr[i]-1,(因为map中存的值序列是连续的,所以看arr[i] - 1 和 arr[i] + 1),如果有,则说明arr[i]-1所在的连续序列可以和arr[i]合并,合并后记为A序列。利用map可以得到A学历低饿长度,记为lenA,最小值记为leftA,最大值记rightA,只在map中更新与leftA和rightA有关的记录,更新成(leftA,lenA)和(rightA,lenA)。接下来看map中是否含有arr[i] + 1,如果有,则说明arr[i] +1所在的连续序列可以和A合并,合并后记为B序列。利用map可以得到B序列的长度为lenB,最小值记录为leftB,最大值记为rightB,只在map中更新与leftB和rightB有关的记录,更新成(leftB,lenB)和(rightB,lenB)。

3.遍历的过程中用全局变脸max记录每次合并出的序列的长度最大值,最后返回max。

public int longestConsecutive(int[] arr){if(arr == null || arr.length == 0){return 0;}int max = 1;HashMap<Integer,Integer> map = new HashMap<Integer,Integer>();for(int i = 0;i<arr.length;i++){if(!map.containsKey(arr[i])){map.put(arr[i],1);if(map.containsKey(arr[i] - 1)){max = Math.max(max,merge(map,arr[i] - 1),arr[i]);}if(map.containsKey(arr[i] + 1)){max = Math.max(max,merge(map,arr[i],arr[i]-1));}}}return max;
}public int merge(HashMap<Integer,Integer> map, int less ,int more){int left = less  - map.get(less) + 1;int right = more + map.get(more) - 1;int len = right - left +1;map.put(left,len);map.put(right,len);return len;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/47996.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android Display Graphics #从Activity看surface的创建(1)

如果图片链接失败&#xff0c;请扫码查看文章详情。 Android Display Graphics系列文章-汇总 系列文章请扫关注公众号&#xff01; 创建Activity Activity是Android系统的应用组件&#xff0c;一般情况下&#xff0c;开发者显示的内容是通过Activity展示的。比如 使用Androi…

pdf文件太大如何压缩变小一点?这几种压缩方法很实用!

pdf文件太大如何压缩变小一点&#xff1f;在日常工作与学习的海洋里&#xff0c;我们时常遭遇PDF文件的“重量级”挑战&#xff0c;这些体积庞大的文档&#xff0c;如同数字世界的巨石&#xff0c;不仅吞噬着宝贵的存储资源&#xff0c;还拖慢了处理速度&#xff0c;影响设备性…

单链表算法 - 链表的回文结构

链表的回文结构_牛客题霸_牛客网对于一个链表&#xff0c;请设计一个时间复杂度为O(n),额外空间复杂度为O(1)的算法&#xff0c;判断其是否为。题目来自【牛客题霸】https://www.nowcoder.com/practice/d281619e4b3e4a60a2cc66ea32855bfa思路1: /* struct ListNode {int val;st…

探索Sklearn中的分层聚类:数据的智能分组艺术

探索Sklearn中的分层聚类&#xff1a;数据的智能分组艺术 在数据科学领域&#xff0c;聚类是一种将数据点分组成多个簇的无监督学习方法&#xff0c;目的是使得同一簇内的数据点相似度高&#xff0c;而不同簇之间的数据点相似度低。分层聚类&#xff08;Hierarchical Clusteri…

.net dataexcel 脚本公式 函数源码

示例如: ScriptExec(""sum(1, 2, 3, 4)"") 结果等于10 using Feng.Excel.Builder; using Feng.Excel.Collections; using Feng.Excel.Interfaces; using Feng.Script.CBEexpress; using Feng.Script.Method; using System; using System.Collections.Gen…

MATLAB R2023b下载安装教程汉化中文版设置

MATLAB R2023b下载安装教程汉化中文版设置 Matlab 是一款功能强大的商业数学软件 Matlab&#xff08;Matrix Labortory&#xff09;即矩阵实验室&#xff0c;它在数值计算、数据分析、算法开发、建模与仿真等众多领域都发挥着重要作用。 Matlab 具有以下显著特点和优势&…

TYPE-C接口PD取电快充协议芯片ECP5701:支持PD 2.0和PD 3.0(5V,9V,12V,15V,20V)

随着智能设备的普及&#xff0c;快充技术成为了越来越多用户的刚需。而TYPE-C接口作为新一代的USB接口&#xff0c;具有正反插、传输速度快、充电体验好等优点&#xff0c;已经成为了快充技术的主要接口形式。而TYPE-C接口的PD&#xff08;Power Delivery&#xff09;取电快充协…

MySQL学习记录 —— 이십삼 MySQL服务器文件系统(3)

文章目录 1、数据字典2、系统表各种系统表 Mysql Schema是⼀个系统库&#xff0c;表中存储了MySQL服务器运行时所需的信息。广义上&#xff0c;mysql schema包含存储MySQL程序基本数据的数据字典和用于其他操作目的的系统表。数据字典表和系统表位于数据目录下一个名为mysql.ib…

角点检测及MATLAB实现

一、角点简介 角点通常指的是两条直线构成角时的交点。‌在更广泛的应用中&#xff0c;‌角点这一概念也被扩展到数字图像处理领域&#xff0c;‌其中角点被定义为图像中物体轮廓线的连接点&#xff0c;‌这些点在某方面属性特别突出&#xff0c;‌即在某些属性上强度最大或者最…

股票行情接口,接入方法对比

Websocket和Http接入方式区别 股票行情数据对投资者和交易员而言极其重要。借助股票行情接口&#xff0c;能够便捷获取实时股票行情数据&#xff0c;从而及时做出决策。股票行情接口通常分为两种&#xff0c;分别是 WebSocket 和 http。 通过 WebSocket 能够获取逐笔的股票 t…

为什么不要碰自媒体

要是失业了&#xff0c;搞自媒体&#xff0c;可行吗&#xff1f;毫无希望&#xff01; 如今的自媒体早卷得不成样子了&#xff0c;很难再有机会&#xff0c;根本原因在于几乎没有增量用户的同时&#xff0c;存量用户也不再有剩余时间&#xff0c;全量用户的时间早已被几个自媒…

空间计算开发:Volu的集成开发工具包

在空间计算技术迅速发展的今天,VR和AR项目的开发需求日益增长。Volu,一个面向空间计算赛道的开发者工具,正致力于简化这一过程。本文将深入探讨Volu如何通过其集成环境,为开发者提供一站式的解决方案。 一、定位:空间计算的得力助手 Volu定位为一个专为空间开发设计的集…

verilog基础语法入门

文章目录 前言一、模块定义1. 模块声明2. 端口定义3. 信号类型声明4. 逻辑功能定义 二、运算符与表达式1. 算术运算符2. 逻辑运算符3. 位运算符4. 关系运算符5. 等式运算符6. 缩减运算符7. 移位运算符8. 条件运算符9. 位拼接运算符 三、语句1. 赋值语句2. 块语句3. 条件语句4. …

麦芒30全新绽放,中国电信勾勒出AI手机的新方向

高通总裁兼CEO克里斯蒂亚诺阿蒙曾在媒体采访时表示&#xff1a;2024年将成为全球AI手机元年&#xff0c;生成式AI正在“非常快”的进入手机。 把大模型装进手机&#xff0c;由此成了智能终端演进的新方向。三星、华为、OPPO、小米等品牌动作频频&#xff0c;纷纷抢滩AI手机市场…

深入理解 Vue.js 的生命周期:从创建到销毁

Vue.js 是一个渐进式的 JavaScript 框架&#xff0c;广泛用于构建用户界面。理解 Vue.js 的生命周期不仅有助于优化性能&#xff0c;还能帮助开发者更好地管理组件的状态和行为。在这篇博客中&#xff0c;我们将深入探讨 Vue.js 的生命周期&#xff0c;并通过代码示例来展示每个…

HarmonyOS NEXT学习——@Styles、@Extend、stateStyles

Styles装饰器 定义组件重用样式 仅支持通用属性和通用事件不支持参数可以定义全局和组件内使用&#xff0c;全局使用需要加function // 全局 Styles function functionName() { ... }// 在组件内 Component struct FancyUse {Styles fancy() {.height(100)} }组件内Styles的优…

Pliops XDP与国产SSD大普微合作

以色列的Pliops公司开发出了XDP&#xff08;Extreme Data Processor&#xff09;AccelKV&#xff0c;这是一种基于键值存储技术的PCIe卡&#xff0c;能够为诸如RocksDB和RAID等应用从主机x86服务器卸载并加速底层存储堆栈处理。Pliops最近与Hammerspace建立了合作关系&#xff…

探索数据的隐藏维度:使用Scikit-Learn进行特征交互性预测

探索数据的隐藏维度&#xff1a;使用Scikit-Learn进行特征交互性预测 在机器学习中&#xff0c;特征交互性是指不同特征之间可能存在的复杂关系&#xff0c;这些关系对预测结果有着重要影响。Scikit-Learn&#xff08;简称sklearn&#xff09;&#xff0c;作为Python中广受欢迎…

C# 之工控机数据类型 高低位(大小端)、BitConverter、IsLittleEndian、字节数组转换(高低位)

八种基本数据类型&#xff1a;byte、short、int、long、float、double、boolean、char byte 8位、有符号的以二进制补码表示的整数 min : -128&#xff08;-2^7&#xff09; max: 127(2^7-1) default: 0 对应包装类&#xff1a;Byte short 16位、有符号的以二进制补码表示…

keil中GD32 MCU IAP中APP的存储地址如何设置?

前面和大家聊过什么是IAP&#xff0c;那么IAP中APP的存储地址该如何设置呢&#xff1f; 以keil为例&#xff0c;打开工程的option选项卡&#xff1a; 将IROM1中的地址改为你想要保存的位置&#xff0c;比如0x08008000开始的位置&#xff1a; 这样通过keil烧录&#xff0c;程序…