lintcode 132 模式
题目要求
给你一个 n 个整数的序列 a1,a2,...,an,一个 132 模式是对于一个子串 ai,aj,ak,满足 i < j < k 和 ai < ak < aj。设计一个算法来检查输入的这 n 个整数的序列中是否存在132模式。n 会小于 20,000。
样例
给你序列 nums = [1,2,3,4]
返回 False//没有132模式在这个序列中。
给你序列 nums = [3,1,4,2]
返回 True//存在132模式:[1,4,2]。
分析
这道题刚做的时候没有看清楚题意,结果写成了连续连续三个数的132模式Orz。后来想了挺久没什么思路于是谷歌了一下,搜到了几种做法好好学习了一下。
- 首先我们的目标是,要寻找三个满足某种关系的数是否在一个列表nums[]中出现。很容易想到我们可以用一个三重循环暴力枚举就好了,显然我们是不可能用这种方法的。那有什么方法呢?凭着多年的数学经验,直觉告诉我们,要找三个索引有序的数i, j, k我们应该把目标设为中间那个j。
- 我们可以通过遍历来寻找j,那么找出j后呢?我们需要找到比j小的那个i,i值得选择是nums中前j个数的最小值,要找最小值的话有个非常好的方法,那就是创建一个数组,数组的值为前“索引”个数的最小值,举个例子
list = [14, 5, 7, 4, 9, 10, 2, 8]
minp[0] = 14 //[14]中14最小
minp[1] = 5 //[14, 5]中5最小
minp[2] = 5
minp[3] = 4
minp[5] = 4
.
minp[6] = 2
minp[7] = 2 //[14, 5, 7, 4, 9, 10, 2, 8]中2最小 - 在花费O(n)的时间复杂度找出所有位置处的数之前的最小值后,那在我们遍历j时,那么之后只需要把目光集中在判断
nums[j] > nums[k] and minp[j] < nums[k]
那么这个k我们需要怎么找呢?我们可以在这之后用一个二重循环来枚举j,k,但是我们需要更快的方法,我们之所以想用二重循环是因为我们想让j,k的位置同时移动并且记录它们的值,那有没有什么办法可以在一个循环内控制j,k的移动和记录呢?答案是有的,我们可以利用栈,我们利用列表nums和栈Kstack。nums同时负责j,k的移动但只记录j,利用辅助栈Kstack来记录k的值.
- 我们从后往前遍历j,当满足第一个最简单的要求后开始j,k的判断,把不满足条件的num[j]压入Kstack中当做k的备用,再往前移动,直到满足j值大于Kstack的top值后再把Kstack中的top值拉出和minp[j]比较即可
class Solution:
"""
@param: nums: a list of n integers
@return: true if there is a 132 pattern or false
""" def find132pattern(self, nums):
# write your code here Kstack = []
n = len(nums)
if n < 3:
return False
minp = n * [0]
minp[0] = nums[0] for i in range(1, n):
minp[i] = min(minp[i - 1], nums[i]) for j in range(n - 1, 0, -1):
if nums[j] > minp[j]:
max = -sys.maxsize
while len(stack) > 0 and nums[j] > Kstack[-1]:
max = Kstack.pop()
if max > minp[j - 1]:
return True
Kstack.append(nums[j])
return False
lintcode 132 模式的更多相关文章
- [LeetCode] 132 Pattern 132模式
Given a sequence of n integers a1, a2, ..., an, a 132 pattern is a subsequence ai, aj, ak such that ...
- [Swift]LeetCode456. 132模式 | 132 Pattern
Given a sequence of n integers a1, a2, ..., an, a 132 pattern is a subsequence ai, aj, ak such that ...
- Leetcode 456.132模式
132模式 给定一个整数序列:a1, a2, ..., an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j < k 时,ai < ak < aj.设计 ...
- 456 132 Pattern 132模式
给定一个整数序列:a1, a2, ..., an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j < k 时,ai < ak < aj.设计一个算法,当 ...
- LeetCode——456.132模式
给定一个整数序列:a1, a2, ..., an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j < k 时,ai < ak < aj.设计一个算法,当 ...
- Java实现 LeetCode 456 132模式
456. 132模式 给定一个整数序列:a1, a2, -, an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j < k 时,ai < ak < aj ...
- 【python】Leetcode每日一题-132模式
[python]Leetcode每日一题-132模式 [题目描述] 给定一个整数序列:a1, a2, ..., an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j &l ...
- 【LeetCode】456. 132 Pattern
Given a sequence of n integers a1, a2, ..., an, a 132 pattern is a subsequence ai, aj, ak such that ...
- [leetcode] 456. 132 Pattern (Medium)
对一个三个元素以上的数组,如果存在1-3-2模式的组合,则返回true. 1-3-2模式就是值的排序是i<k<j但是下标排序是i<j<k. 解法一: 硬解,利用一个变量存储是否 ...
随机推荐
- 编程从入门到提高,然后放弃再跑路(Java)
1.Java入门篇 1.1 基础入门和面向对象 1.1.1 编程基础 [01] Java语言的基本认识 [02] 类和对象 [03] 类的结构和创建对象 [04] 包和访问权限修饰符 [05] 利用p ...
- 04面向对象编程-02-原型继承 和 ES6的class继承
1.原型继承 在上一篇中,我们提到,JS中原型继承的本质,实际上就是 "将构造函数的原型对象,指向由另一个构造函数创建的实例". 这里,我们就原型继承的概念,再进行详细的理解.首先 ...
- Java实现MD5加密_字符串加密_文件加密
Java实现MD5加密,具体代码如下: package com.bstek.tools; import java.io.FileInputStream; import java.io.IOExcept ...
- java ee Servlet 开发框架分享
大家好! 这里分享一下javaEE Servlet开发框架! 1.首先是POST和GET入口以及接收处理文件 package com.sl.imps; import java.io.IOExcepti ...
- JAVA设计模式总结之六大设计原则
从今年的七月份开始学习设计模式到9月底,设计模式全部学完了,在学习期间,总共过了两篇:第一篇看完设计模式后,感觉只是脑子里面有印象但无法言语.于是决定在看一篇,到9月份第二篇设计模式总于看完了,这一篇 ...
- asp.net core合并压缩资源文件引发的学习之旅
0. 在asp.net core中使用BuildBundlerMinifier合并压缩资源文件 在asp.net mvc中可以使用Bundle来压缩合并css,js 不知道的见:http://www. ...
- Glide 这样用,更省内存!!!
一.前言 Glide 是 Google 官方推荐的一款图片加载库,使用起来也非常的简单便利,Glide 它帮我们完成了很多很重要,但是却通用的功能,例如:图片的加载压缩.展示.加载图片的内存管理等等. ...
- 浅析前端开发中的 MVC/MVP/MVVM 模式
MVC,MVP和MVVM都是常见的软件架构设计模式(Architectural Pattern),它通过分离关注点来改进代码的组织方式.不同于设计模式(Design Pattern),只是为了解决一类 ...
- Python数据分析(二): Numpy技巧 (1/4)
In [1]: import numpy numpy.__version__ Out[1]: '1.13.1' In [2]: import numpy as np
- JavaWeb(一)Servlet中的request与response
一.HttpServletRequest概述 1.1.HttpServletRequest简介 HttpServletRequest对象代表客户端的请求,当客户端通过HTTP协议访问服务器时,HTTP ...