最长连续序列
原题在这里:
概述题意,给定一个无序可重复元素数组,问数组中构成的最长连续数值长度。
要求O(n)时间复杂度。
analyse:
1.初始想法,set+mp遍历,时间复杂度还行。
code:
 
class Solution { public: int longestConsecutive(vector<int> &nums) { // 13:30 int ans = 0; set<int> st; map<int, int> mp; for (int i : nums) st.insert(i); for (int i : st) { mp[i] = max(mp[i - 1] + 1, mp[i]); ans = max(ans, mp[i]); } return ans; } };
2.标准解法,还是用了set,基于此,每次统计选用st.count(x-1)==0时候开始统计
code:(100ms)
class Solution { public: int longestConsecutive(vector<int> &nums) { int ans = 0; unordered_set<int> st; for (int i : nums) st.insert(i); for (int i : st) { if (!st.count(i - 1)) { int x = 1; while (st.count(i + x)) ++x; ans = max(ans, x); } } return ans; } };
【Over】
 
                    
                     
                    
                 
                    
                
 
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号