【leetcode】26. Remove Duplicates from Sorted Array
2016-06-06 15:44
337 查看
/** * Given a sorted array, remove the duplicates in place such that each element appear only once and return the new length. * * Do not allocate extra space for another array, you must do this in place with constant memory. * * For example, * Given input array nums = [1,1,2], * * Your function should return length = 2, with the first two elements of nums being 1 and 2 respectively. * It doesn't matter what you leave beyond the new length. */ #include <iostream> #include <string> #include <vector> using namespace std; int removeDuplicates(vector<int>& nums) { if (nums.empty()) return 0; int counter = 0; int val = nums.front(); int len = nums.size(); vector<int>::iterator it = nums.begin(); for (++it; it != nums.end(); ) { if (*it == val) { counter++; it = nums.erase(it); } if (*it != val) { val = *it; it++; } } return len - counter; } //leetcode想法 int removeDuplicates1(vector<int>& nums) { int i = 0; for (int n : nums) if (!i || n > nums[i - 1]) nums[i++] = n; return i; } int main_l26() { vector<int> nums{1, 1, 1, 2, 2, 2, 3}; cout << removeDuplicates(nums); system("pause"); return 0; }
相关文章推荐
- leetcode 179 Largest Number
- leetcode 24 Swap Nodes in Pairs
- leetcode 2 Add Two Numbers 方法1
- leetcode 2 Add Two Numbers 方法2
- leetcode----Longest Substring Without Repeating Characters
- [LeetCode]47 Permutations II
- [LeetCode]65 Valid Number
- [LeetCode]123 Best Time to Buy and Sell Stock III
- [LeetCode] String Reorder Distance Apart
- [LeetCode] Sliding Window Maximum
- [LeetCode] Find the k-th Smallest Element in the Union of Two Sorted Arrays
- [LeetCode] Determine If Two Rectangles Overlap
- [LeetCode] A Distance Maximizing Problem
- leetcode_linearList
- leetcode_linearList02
- 021-Merge Two Sorted Lists(合并两个排好序的单链表);leetcode
- LeetCode[Day 1] Two Sum 题解
- LeetCode[Day 2] Median of Two Sorted Arrays 题解
- LeetCode[Day 3] Longest Substring Without... 题解
- LeetCode [Day 4] Add Two Numbers 题解