国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java去除已排序數組中的重復元素

2019-11-26 13:49:35
字體:
來源:轉載
供稿:網友

題目描述

給定一個已排序的數組,去除數組中的重復元素,只保留一個重復的元素,并且返回新的數組長度。

要求:
不要給數組分配額外的空間,你必須使用常量的內存大小進行原地操作。

例如:
給出數組A=[1,1,2],你的函數調用之后必須返回長度length=2,并且A現在變成[1,2]。

輸入

一個已排序的數組,例如[1,1,2]。

輸出

返回數組新的長度,例如length=2。

快慢指針法

設置fast指針遍歷數組,slow指針指向不重復元素的下一位。

public static int removeDuplicates(int[] nums){  if (nums.length < 1)    return nums.length;  int slow = 1;  for (int fast = 1; fast < nums.length; fast++) {    if (nums[fast] != nums[slow - 1]) {      nums[slow++] = nums[fast];    }  }  return slow;}

動畫演示:

擴展

去除已排序數組中的重復元素,保留指定位數。

public static int removeDuplicatesN(int[] nums, int repeatN){ if (nums.length <= repeatN)  return nums.length; int index = repeatN; for (int i = repeatN; i < nums.length; i++) {  if (nums[i] != nums[index - repeatN]) {   nums[index++] = nums[i];  } } return index;}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 桐庐县| 友谊县| 宜阳县| 花垣县| 阿拉善盟| 淳安县| 饶阳县| 历史| 苏州市| 土默特左旗| 正蓝旗| 金溪县| 云梦县| 雅安市| 辽阳县| 汶上县| 晋州市| 化州市| 岱山县| 瓦房店市| 嘉黎县| 枣庄市| 威宁| 思南县| 佛冈县| 建宁县| 临沧市| 准格尔旗| 松阳县| 沽源县| 衡水市| 涞水县| 嘉义县| 同江市| 依安县| 五台县| 田林县| 板桥市| 东明县| 怀化市| 绿春县|