日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[剑指offer][JAVA]面试题第[03]题[数组中的重复数字][HashSet]

發布時間:2023/12/10 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [剑指offer][JAVA]面试题第[03]题[数组中的重复数字][HashSet] 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

【問題描述】[數組中的重復數字][簡單]

找出數組中重復的數字。 在一個長度為 n 的數組 nums 里的所有數字都在 0~n-1 的范圍內。數組中某些數字是重復的,但不知道有幾個數字重復了,也不知道每個數字重復了幾次。請找出數組中任意一個重復的數字。輸入: [2, 3, 1, 0, 2, 5, 3] 輸出:2 或 3

【解答思路】

1. 排序后比較

時間復雜度:O(NlogN) 空間復雜度:O(1)

class Solution {public int findRepeatNumber(int[] nums) {Arrays.sort(nums);for(int i=0;i<nums.length-1;i++){if(nums[i]==nums[i+1]){return nums[i];}}return -1;} }
2. HashSet

時間復雜度:O(N) 空間復雜度:O(N)

public int findDuplicate(int[] nums) {HashSet<Integer> set = new HashSet<>();for (int i = 0; i <= nums.length - 1; i++) {if (set.contains(nums[i])) {return nums[i];}else{set.add(nums[i]);}}return -1; }
3.原地置換


時間復雜度:O(N) 空間復雜度:O(1)

class Solution {public int findRepeatNumber(int[] nums) {int i = 0;while(i < nums.length) {if(nums[i] == i) {i++;continue;}if(nums[nums[i]] == nums[i]) return nums[i];int tmp = nums[i];nums[i] = nums[tmp];nums[tmp] = tmp; //nums[nums[i]], nums[i] = nums[i], nums[nums[i]],為什么這里的交換可以讓元素的 索引 與 值 相等。//下面供大家方便看出來(因為我看了好久才反應過來)://記num[ i ] =a,num[num[ i ] ]=num[ a ]=b,那么 交換后,num[ i ]=b, num[num[i]]=num[a]=a,這時候下標 a 對應的元素也是a,達到目的}return -1;} }

【總結】

1.考察的是程序員的溝通能力,先問面試官要時間/空間需求
  • 時間優先就用字典,
  • 有空間要求,就用指針+原地排序數組
  • 要求空間O(1)并且不能修改原數組,還得寫成二分法
2.靈活思路 一題多解
3. HashMap 或 HashSet常見用法

3.1 HashSet

新建 HashSet<Integer> set = new HashSet<>();

(1)增加
public boolean add(E e);
(2)刪除
public boolean remove(Object j);
(3)對比查找
public boolean contains(Object j);
(4)清空集合
public void clear();
(5)獲取長度
public int size();
3.2 HashMap

新建 HashMap<String,Integer> map= new HashMap<String,Integer>();

(1) 插入鍵值對數據
public V put(K key, V value)
(2)根據鍵值獲取鍵值對值數據
public V get(Object key)
(3)獲取Map中鍵值對的個數
public int size()
(4)判斷Map集合中是否包含鍵為key的鍵值對
public boolean containsKey(Object key)
(5)判斷Map集合中是否包含值為value的鍵值對
boolean containsValue(Object value)
(6)判斷Map集合中是否沒有任何鍵值對
public boolean isEmpty()
(7)清空Map集合中所有的鍵值對
public void clear()
(8)根據鍵值刪除Map中鍵值對
public V remove(Object key)

總結

以上是生活随笔為你收集整理的[剑指offer][JAVA]面试题第[03]题[数组中的重复数字][HashSet]的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 依依成人在线 | 日韩高清专区 | 亚洲国产精华液网站w | 亚洲国产精品久久AV | 日本一区二区三区欧美 | 美女少妇一区二区 | 日本一级视频 | 奇米第四色在线 | 在线亚洲人成电影网站色www | 久久综合五月 | 夜夜爽夜夜操 | 亚洲色图图片区 | 欧美大片高清免费观看 | 午夜性福利 | 最好看的2019年中文在线观看 | 亚洲小说春色综合另类 | 短裙公车被强好爽h吃奶视频 | 国产成人无码精品久久久久 | 秋霞福利影院 | 中文字幕国内自拍 | 免费看成人毛片 | 成年人黄色免费视频 | 光棍影院手机版在线观看免费 | 激情 小说 亚洲 图片 伦 | 欢乐谷在线观看免费播放高清 | 国产一区二区三区视频在线观看 | 久久yy | 精品久久久久久国产 | 老熟妇午夜毛片一区二区三区 | 男人天堂资源 | 久久福利网 | 天堂网一区二区三区 | 美日韩在线观看 | 台湾佬av| 日本精品少妇 | 免看一级a毛片一片成人不卡 | 国产美女在线免费观看 | 中文字幕av有码 | 国精产品一区一区三区免费视频 | 国内视频一区二区三区 | 91蝌蚪少妇 | 成人在线h | 领导揉我胸亲奶揉下面 | 精品国产午夜福利在线观看 | 激情a | 97精品人妻一区二区三区香蕉 | 日本二三区 | 制服.丝袜.亚洲.中文.综合懂色 | 欧美婷婷六月丁香综合色 | 91成人免费在线观看 | 午夜视频| 久久久久久无码精品大片 | 九九涩| 天天看天天干 | 成人免费看 | 免费av看 | 清纯唯美亚洲综合 | 日韩激情视频一区二区 | 亚洲最大视频网 | 欧美日韩在线观看成人 | 奶水喷溅虐奶乳奴h文 | 日本在线视频免费观看 | 性生交大片免费看狂欲 | 福利视频在线 | 成人欧美一级特黄 | 一级免费a | 香蕉久久夜色精品国产使用方法 | 日本中文字幕在线不卡 | 星空大象mv高清在线观看免费 | 亚洲啊啊 | 成人免费观看视频网站 | 深夜国产福利 | 秋霞影院午夜伦 | 亚洲视频天天射 | 一级片在线视频 | 中文毛片无遮挡高潮免费 | 羞羞在线观看 | 成人性视频在线 | 青青视频免费在线观看 | 亚洲国产剧情 | 国产精品第一页在线观看 | 天天射天天操天天干 | 少妇又色又紧又黄又刺激免费 | 久久人人爽人人爽人人片亚洲 | 狠狠干2024 | 欧美精品黄 | 亚洲国产久 | 视频在线观看电影完整版高清免费 | 欧美aaa级片 | 亚洲一在线 | 99热这里只 | 极品少妇一区二区 | 性欧美18—19sex性高清 | 特黄特色大片免费视频大全 | 凹凸国产熟女精品视频 | 国产精品va无码一区二区三区 | 伊人色综合久久天天 | 日本人与黑人做爰视频 | 国产精品无码久久av |