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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

数据结构课程笔记1-水王问题

發布時間:2023/12/16 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据结构课程笔记1-水王问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目

給定一個數組,若數組里存在某個數字,其數量超過數組長度的一半以上,則稱該數為水王數字。
例如數組[3,2,1,2,3,3,4,3,3],數字3為水王數字。若不存在水王數字,則返回-1;

要求時間復雜度:o(n),空間復雜度:o(1)

解法一 (空間復雜度不滿足要求)

思路:遍歷數組,使用一個map來記錄數字出現次數,找出出現次數大于數組長度1/2的數字。

public static int waterKing(int[] nums) {int result = -1;if (nums != null || nums.length != 0) {Map<Integer, Integer> map = new HashMap<>();for (int key : nums) {int count = map.getOrDefault(key, 0) + 1;map.put(key, count);if (count > nums.length / 2) {result = key;break;}}}return result;}

解法二 (滿足時間與空間復雜度要求)

思路:遍歷數組,若兩個數不同,則同時刪除,若相同,則保留,繼續遍歷。到最后,由于水王數字超過數組長度的1/2,若存在,一定可以留下。

代碼思路:使用兩個變量,一個為候選,一個為血量。血量記錄候選出現的次數,當血量為0時,說明此時還沒有真正的候選,可以將當前數字設置為候選,血量為1,繼續遍歷。若血量不為0,說明有候選,將候選數字與當前數字做對比,若相等,則候選血量加1,若不相等,則候選血量減少1。遍歷完之后,若血量大于0,說明候選有可能真的為血王數字。再次遍歷一遍數字,看是否候選數字次數大于數組長度的1/2。

代碼:

public static int waterKing(int[] nums) {int candidate = 0;int restHP = 0;if (Objects.requireNonNull(nums).length > 0) {for (int key : nums) {if (restHP == 0) {candidate = key;restHP++;} else if (key == candidate) {restHP++;} else {restHP--;}}if (restHP != 0) {restHP = 0;for (int key : nums) {if (key == candidate) {restHP++;}}}}return restHP > nums.length / 2 ? candidate : -1;}

總結

以上是生活随笔為你收集整理的数据结构课程笔记1-水王问题的全部內容,希望文章能夠幫你解決所遇到的問題。

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