给定一个整数序列:a1, a2, ..., an,一个132模式的子序列 ai, aj, ak 被定义为:当 i < j < k 时,ai < ak < aj。设计一个算法,当给定有 n 个数字的序列时,验证这个序列中是否含有132模式的子序列。
注意:n 的值小于15000。
示例1:
输入: [1, 2, 3, 4] 输出: False 解释: 序列中不存在132模式的子序列。
示例 2:
输入: [3, 1, 4, 2] 输出: True 解释: 序列中有 1 个132模式的子序列: [1, 4, 2].
示例 3:
输入: [-1, 3, 2, 0] 输出: True 解释: 序列中有 3 个132模式的的子序列: [-1, 3, 2], [-1, 3, 0] 和 [-1, 2, 0].
leetcode代码
class Solution { public: bool find132pattern(vector<int>& nums) { vector<int> nums2; for(int i=1;i<nums.size();i++) { if(nums[i]==nums[i-1]) nums[i-1]=-100; } for(int i=0;i<nums.size();i++){ if(nums[i]!=-100) nums2.push_back(nums[i]); } if(nums2.size()<3) return false; for(int i=0;i<nums2.size()-2;i++) { int max=nums2[i]; int j,tempj; for(j=i+1;j<nums2.size()-1;j++){ if(nums2[j]>max) {max=nums2[j];tempj=j;} } if(max==nums2[i]) continue; for(int k=tempj+1;k<nums2.size();k++){ if(nums2[i]<nums2[k]&&nums2[k]<nums2[tempj]) return true; } } return false; } };