最长等差数列_最长等差数列分析

原题

给定未排序的数组,请给出方法找到最长的等差数列。

分析

题目描述比较简单,但是有一个问题我们需要首先搞清楚:等差数列中的数字,是否要和原始数组中的顺序一致。题目中,并没有说明,这个就需要大家在面试的过程中和面试官进行交流。我们在这里对两种情况都进行讨论:

保证数字的顺序

等差数列是要求相邻两个元素之间的差是相同的。那我们可以记录下来数组中任意两个数的差,并且记录下来。对于数组A,记录A[j]-A[i],其中 i

构造hashmap如下:

-1=>(0,1)(1,2)

1=>(2,3)(4,5)

3=>(3,4)

上面已经排好序,对于第一个,找到等差数列0,1,2对应数字诶5,4,3.第二个,3和4位置没有连起来,不够成等差数列。方法平均时间复杂度为O(n^2),空间复杂度为O(n^2).

无需保证数字的顺序

不需要保证数字的顺序与原来数组一致,如何找到最长的等差数列呢?原来的数组是无序的,我们先对数组进行排序,最终的一定是排序之后序列的子序列。然后,我们采用动态规划的方法解决这个问题。

我们假设dp[i][j]表示以A[i]A[j]开始的数列的长度(数列的前两项),dp[i][j]如何表示呢?dp[i][j]=dp[j][k]+1,当 A[j]-A[i]=A[k]-A[j],及A[k]+A[i]=2*A[j]。根据dp[i][j]的定义,我们知道dp[x][n-1]=2,也就是 最后一列是2,数列只有A[x]和A[n-1]两个元素。首先,j从n-2,开始向前遍历,对于每一个,找到i和k,满足 A[k]+A[i]=2*A[j],则有dp[i][j]=dp[j][k]+1,若没有,则dp[i][j]就为2.

这里找i和k,有一个小技巧,如下:初始i=j-1,k=j+1,然后分别向两边遍历,如果A[k]+A[i]=2*A[j]则i--。大家还是参考代码吧:

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

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

相关文章

Mybatis中注解@MapKey的使用详解

MyBatis查询一些记录,数据涉及到两个表里的数据,需要连表查询,但我MyBatis的返回结果不想创建新的DO对象,因此使用MapKey注解返回一个Map集合。 含义:MapKey注解用于mapper.xml文件中,一般用于查询多条记录…

JMeter测试组件

JMeter的主要测试组件 1、测试计划是使用JMeter进行测试的起点,它是其它JMeter测试元件的容器。 2、线程组代表一定数量的并发用户,它可以用来模拟并发用户发送请求。实际的请求内容在Sampler中定义,它被线程组包含。 3、监听器负责收集测试结…

aes js 加盐值 解密_Java已有AES加解密,现需要前端Javascript加密调接口,返回的数据需要解密,目前互..._慕课猿问...

目前Javascript使用crypto-js包。前后台可以自己跑通加解密,但是,无法互通。针对对象{}加密……网上的方案,已经尝试了4天左右了,还没成功,请指导。无思路,无报错。Javapackage com.pactera.sms.foundbase.…

springboot 1.5.2 集成kafka 简单例子

添加依赖 compile("org.springframework.kafka:spring-kafka:1.1.2.RELEASE") 添加application.properties #kafka # 指定kafka 代理地址,可以多个 spring.kafka.bootstrap-servers192.168.59.130:9092,192.168.59.131:9092,192.168.59.132:9092 # 指定默…

更新 绑定数据_Blazor 修仙之旅 组件与数据绑定

一.前言在第一篇文章初尝 Blazor WebAssembly中,有提到过组件(Component)这个概念。组件在 Blazor 中是必不可少的,UI 全靠它组装起来,和前端的 JS 组件是一个意思,比如:vue component、react component 等等。借用官方…

Struts2 拦截器: 拦截器与过滤器区别

1、首先要明确什么是拦截器、什么是过滤器 1.1 什么是拦截器: 拦截器,在AOP(Aspect-Oriented Programming)中用于在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作。拦截是AOP的一种实现策略。…

关于使用idea工具debug时,断点颜色由红色变成灰色解决方法

在使用断点调试的时候,发现断点由原来的红色变成灰色的,后来发现是由于错误操作将Debug断点调试禁用了 ,只需要点击禁用按钮取消就可以了

改变图标颜色_LOL设计师宣布修改装备图标:提高清晰度、颜色差异化

在11月12日,英雄联盟更新到了最新的季前赛版本。这次官方除了对部分英雄进行改动,主要是对于装备的图标和属性进行了更新。而在图标更新后,很多装备的样子都发生了很大的变化。这也导致很多老玩家在进游戏后,看着装备栏发呆&#…

虚拟机中centos安装gcc

yum install gcc-c 一、首先是:使得虚拟机联网 使用NAT模式 虚拟机网络连接使用NAT模式,物理机网络连接使用Vmnet8。 虚拟机设置里面——网络适配器,网络连接选择NAT模式。 虚拟机菜单栏—编辑—虚拟网络编辑器,选择Vmnet8 NAT模式…

python查看汉字的编码_python有关汉字编码问题

python分为:程序编码(python安装程序)、文件编码。查看程序编码方式:sys.getdefaultencoding()查看文件编码方式:1.import chardet 2. f open(lianxi1-qus.py) data f.read() print chardet.detect(data)字符编码发展历程&#…

gcd(欧几里得算法)

基础 1 int gcd(int a,int b) 2 { 3 int r; 4 while(b>0) 5 { 6 ra%b; 7 ab; 8 br; 9 } 10 return a; 11 } View Code递归 1 int gcd(int a,int b) 2 { 3 return (b>0)?gcd(b,a%b):a; 4 } Vi…

网络摄像头sdk_SenseDLC嵌入式人像识别SDK 安防边缘的“小巨人”

随着这些年将人工智能技术赋能行业的不断深入,商汤科技对智慧城市建设有着更深的理解。通过不断实践发现,很多区域由于摄像头数量和布置等问题较难有效做到清晰的人脸抓拍,且单一的人脸识别会遇到诸多干扰,比如发型、胖瘦、年纪、…

使用最大似然法来求解线性模型(1)

在Coursera机器学习课程中,第一篇练习就是如何使用最小均方差(Least Square)来求解线性模型中的参数。本文从概率论的角度---最大化似然函数,来求解模型参数,得到线性模型。本文内容来源于:《A First Course of Machine Learning》…

.net aspose.words 域加载图片_使用Python批量替换csdn文章的图片链接

欢迎大家关注我的微信公众号“IT工匠”获取更多资源(涉及算法、数据结构、java、深度学习、计算机网络、python、Android等互联网技术资料)。前言笔者之前的写作习惯一直是在本地(MacTyporaIpac)写好之后将markdown代码粘贴到csdn,图片是Ipac自动上传到微博匿名图床…

Spring积累总结

1.spring 的优点: 1.降低了组件之间的耦合性 ,实现了软件各层之间的解耦 2.可以使用容易提供的众多服务,如事务管理,消息服务等 3.容器提供单例模式支持 4.容器提供了AOP技术,利用它很容易实现如权限拦截&#xff0…

什么是公钥和私钥?

公钥和私钥是通过一种算法得到的一个密钥对(即一个公钥和一个私钥),将其中的一个向外界公开,称为公钥;另一个自己保留,称为私钥。通过这种算法得到的密钥对能保证在世界范围内是唯一的。使用这个密钥对的时候,如果用其…