摘要:思路原數組長度為,則返回原數組長度不為,則至少有個元素。將所有不重復的數值賦給,而當和相等時,不做處理。最后返回的就是不同元素的個數,也是新數組的長度。只有在時,才對賦值。注意,每次初始化的時候要分兩種情況,這就意味著從的時候開始遍歷。
Remove Duplicates from Sorted Array I Problem
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.
ExampleGiven input array A = [1,1,2],
Your function should return length = 2, and A is now [1,2].
Note思路:原數組長度為0,則返回0;原數組長度不為0,則至少有index = 1個元素。循環整個數組,比較nums[i]和nums[i-1]。將所有不重復的數值賦給nums[index],而當nums[i]和nums[i-1]相等時,不做處理。最后返回的index就是不同元素的個數,也是新數組的長度。
Solutionpublic class Solution { public int removeDuplicates(int[] nums) { if (nums.length == 0) return 0; int index = 1; for (int i = 1; i < nums.length; i++) { if (nums[i] != nums[i-1]) nums[index++] = nums[i]; } return index; } }Remove Duplicates from Sorted Array II Problem
Follow up for "Remove Duplicates":
What if duplicates are allowed at most twice?
For example,
Given sorted array A = [1,1,1,2,2,3],
Your function should return length = 5, and A is now [1,1,2,2,3].
Note相同的思路,加入一個count變量,每次循環比較前后元素是否重復時,更新該元素出現的次數count。只有在count <= 2時,才對nums[index]賦值。
注意,每次初始化count的時候要分兩種情況:i == 0 || nums[i] != nums[i-1],這就意味著從i = 0的時候開始遍歷。
public class Solution { public int removeDuplicates(int[] nums) { if (nums.length == 0) return 0; int index = 0, count = 0; for (int i = 0; i < nums.length; i++) { if (i == 0 || nums[i] != nums[i-1]) count = 1; else count++; if (count <= 2) { nums[index] = nums[i]; index++; } } return index; } }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/65830.html
摘要:排序數組中找最小值或最大值的題目,很明顯可以使用二分法。因此,只判斷終點和中點元素的大小關系即可。這里有一種情況是上述后三個,中點值和末位相等。此時,兩邊同時遞歸,并返回兩邊遞歸值的較小值。當首位和末位重合,說明已夾逼得到最小值。 Find Minimum in Rotated Sorted Array Problem Suppose a sorted array is rotated...
Problem Given a sorted array and a target value, return the index if the target is found. If not, return the index where it would be if it were inserted in order. You may assume NO duplicates in the a...
摘要:雙指針法復雜度時間空間思路我們可以將不重復的序列存到數列前面,因為不重復序列的長度一定小于等于總序列,所以不用擔心覆蓋的問題。代碼雙指針法復雜度時間空間思路思路和上題一樣,區別在于記錄前兩個遍歷到的數字來幫助我們判斷是否出現了第三遍。 Remove Duplicates from Sorted Array I Given a sorted array, remove the dupl...
摘要:題目要求翻譯將鏈表中重復的元素全部刪除,返回新的頭結點。相比于,這里將重復的元素全部刪除。除此以外,我們還需要知道重復元素的前一個值和重復元素的最后一個值。如果存在重復值,則跳過重復值后,前節點不變,否則前節點跟隨后節點同時向后移動。 題目要求 Given a sorted linked list, delete all nodes that have duplicate number...
摘要:思路與代碼其實在這里我們仍然延續中的思路。在遇到非重復值以及非多余的重復值時,將數值移動到當前記錄的下標上。保證該下標前的值均為滿足題目條件的值。第一次我使用了來記錄某個值出現的次數。 題目要求 Follow up for Remove Duplicates: What if duplicates are allowed at most twice? For example, Giv...
閱讀 1026·2021-10-19 11:42
閱讀 2981·2021-09-10 10:51
閱讀 689·2021-09-09 09:33
閱讀 1769·2021-09-01 10:43
閱讀 2779·2019-08-30 12:43
閱讀 3526·2019-08-30 11:24
閱讀 2131·2019-08-30 10:56
閱讀 2785·2019-08-29 11:00