LeetCode_491 递增子序列 /大厂笔试题讲解

在这里插入图片描述

一、题目信息

本题和LeetCode_491相同,这里我以牛客网的形式写题。
在这里插入图片描述

二、解题思路

题目要求的只需要找到长度为三的子序列,还不要求是连续的。创建两个引用,first,second,分别表示第一大和第二大的数字,如果遍历的时候数组中还有比他们两个数还大的数字,那长度为3的子序列不就有了吗?如果遍历完了还么有,就说明是真的没有了,返回false。

还有其他两种情况
1、遍历数组的时候遇到的数(这里称为P)first比p大,既然连子序列最小的数都比它大,那么就说明这时候的first不是最小的,更新first,让first=p。

2、P比fist大但是没有second大,大不是很大,但是也不小,这时我们更新
second,第二大的数就有了。

3、图和例子在下方。

在这里插入图片描述

假如下面有以下数组,8,25,13,11,30,数组名为arr。初始化fist为arr[0],second为Integer的最大值。如果还能有数字比second大,那直接返回好了。就是图的第三种情况。我们让i从1开始走一步过程。

1、i=1,arr[i]>first但是小于second更新second,second=arr[i],为25.
2、i=2,arr[i]>first但是小于second,更新second,second=13.
3、i=3,arr[i]>first但是小于second,更新second,second=11.
4、i=4,arr[i]>first,还大于second,找到了!

  • 31
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 42
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 42
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

见闻色霸气~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值