给你一个按升序排序的整数数组 num(可能包含重复数字),请你将它们分割成一个或多个子序列,其中每个子序列都由连续整数组成且长度至少为 3 。
如果可以完成上述分割,则返回 true ;否则,返回 false 。
示例 1:
输入: [1,2,3,3,4,5]
输出: True
解释:
你可以分割出这样两个连续子序列 :
1, 2, 3
3, 4, 5
示例 2:
输入: [1,2,3,3,4,4,5,5]
输出: True
解释:
你可以分割出这样两个连续子序列 :
1, 2, 3, 4, 5
3, 4, 5
示例 3:
输入: [1,2,3,4,4,5]
输出: False
提示:
输入的数组长度范围为 [1, 10000]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/split-array-into-consecutive-subsequences
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
1 class Solution { 2 public: 3 //两个map 4 //第一个map存每个数字出现的次数 count 5 //第二个map tail存以数字i结尾且符合条件的数组的数目 6 //对于数num 如果count[num]>0&&tail[num-1]存在则可将这个num接到num-1这个序列后面 7 //如果!count[num] 则continue 8 //若不满足上述条件 若count[num] count[num+1] count[num+2]存在 则新建满足条件的序列 9 //上述条件都不满足 return false 10 bool isPossible(vector<int>& nums) { 11 unordered_map<int,int> count,tail; 12 for(auto num:nums)count[num]++; 13 for(auto num:nums) 14 { 15 if(count[num]&&tail[num-1]) 16 { 17 count[num]--; 18 tail[num-1]--; 19 tail[num]++; 20 } 21 else if(!count[num])continue; 22 else 23 { 24 if(count[num]&&count[num+1]&&count[num+2]) 25 { 26 tail[num+2]++; 27 count[num]--; 28 count[num+1]--; 29 count[num+2]--; 30 } 31 else return false; 32 } 33 } 34 return true; 35 } 36 };