作者i329 (殺刀豬)
看板Python
標題[問題] 用for迴圈找眾數
時間Mon Mar 21 19:11:39 2022
各位大大安安
小弟正在自學python (
https://tinyurl.com/yu9nfd6f )
迴圈實在弄得我頭痛QQ
有個題目如下:
尋找眾數
numbers_str 是一個使用者輸入的以逗號分隔數字的字串。
從 numbers_str 中找到眾數(最常見的數字)並顯示出:
眾數是{眾數}
提示 1
使用 split() 方法把一個以逗號分隔數字的字串轉換成一個串列。
提示 2
嘗試創造一個字典,其中每個鍵是串列中的一個數字,而值是該數字出現在串列中的次數
。
例如,如果串列是[10, 20, 10, 30],我們要創造以下字典:
{ 10: 2, 20: 1, 30: 1 }
解答如下:
numbers_str = input('請輸入以逗號分隔的一串數字: ') #這是題目已經預設的
numbers = numbers_str.split(',')
# occurrences 儲存一個數字出現的次數
occurrences = {}
for n in numbers:
if n in occurrences:
occurrences[n.strip()] += 1
else:
occurrences[n.strip()] = 1
# mode 是目前最常出現的數字
mode = -1
# mode_count 是 mode 出現的次數
mode_count = 0
for n, count in occurrences.items():
if
mode_count == 0 or mode_count < count:
mode = n
mode_count = count
print(f'眾數是{mode}')
解答到上半部的for都還看得懂
下半部就不懂為什麼要把mode=-1
if的 mode_count < count這個部分也還可以
mode_count == 0 就不懂了
然後我嘗試跑了他的解答
發現答案好像不是完整的眾數
例如我如果輸入的是: 7,7,1,1,8
答案只會出現7 而沒有辦法顯示全部的答案
不太確定是我的問題還是題目沒有出好@@
再拜託各位大大幫忙解答
感謝
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 36.235.193.17 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Python/M.1647861101.A.615.html
※ 編輯: i329 (36.235.193.17 臺灣), 03/21/2022 19:13:42
※ 編輯: i329 (36.235.193.17 臺灣), 03/21/2022 19:14:36
1F:推 DaOppaiLoli: 題目定義不夠嚴謹,沒有說要把次數一樣的都印出來, 03/21 19:20
請教一般要找眾數有其他的方法嗎?
2F:→ DaOppaiLoli: mode 設成 -1 應該是假設數列都是正數 03/21 19:20
3F:→ f416720001: mode -1是因為他已經先把-1列為不可能出現的數,所以 03/21 19:41
4F:→ f416720001: 以它為初始值 03/21 19:41
我剛剛試了 [-1,7,-9,11,-1,3,6,7]
是可以找出-1的 @@ 所以好像沒有限制一定要正數?
然後想問一下mode_count == 0的用意
感謝
※ 編輯: i329 (36.235.193.17 臺灣), 03/21/2022 20:42:23
5F:推 and629: -1 & 0 都是初始化。只要 count > 0 代表新的眾數出現,就 03/21 21:34
6F:→ and629: 把舊的 key取代掉 03/21 21:34
感謝大大回應
請問初始化的話是不是設定任意數都可以呢?
另外不明白已經設定mode_count = 0
那跟後面的mode_count == 0有關係嗎 這個又是什麼意思呢?
※ 編輯: i329 (36.235.193.17 臺灣), 03/21/2022 22:33:07
7F:推 poototo: 造出來的字典你知道長甚麼樣子之後 03/21 22:55
8F:→ poototo: 你不一定要用解答的方式造 03/21 22:55
9F:→ poototo: -1,0 你可以換成其他初始值 03/21 22:56
好的
10F:→ stucode: mode_count == 0 的意思是「當目前沒有任何眾數時,無條 03/21 23:06
11F:→ stucode: 件將目前的 n 當作眾數」。在某些情況下這種條件是有必要 03/21 23:06
12F:→ stucode: 的,但以這個題目來說有點多餘,因為 count 不可能小於 1 03/21 23:06
13F:→ stucode: ,所以第一次進入迴圈 mode_count < count 一定會成立。 03/21 23:06
14F:→ stucode: code 的部份 mode = -1 改成 mode = None 03/21 23:07
15F:→ stucode: 然後 mode_count == 0 去掉,應該就比較好理解 03/21 23:07
我試了一下似乎是可以運行的 感謝
可以請教mode_count == 0在什麼情況下是必要的呢?
16F:推 lycantrope: 初始化並不是任意數都可以... 03/22 09:21
可以請大大講的詳細一點 或是指點方向嗎?
17F:推 pshuang: mode = -1 以下在寫什麼? 為甚麼不直接根據value排序? 03/22 11:26
可以請大大說說看你的想法嗎?
※ 編輯: i329 (36.235.193.17 臺灣), 03/22/2022 12:10:56
18F:→ pshuang: 根據value大到小排序 最前面的就是眾數啊 03/22 13:06
對欸 好像比較好懂
19F:推 lycantrope: 初始化選不含在你數值範圍內的值,例,正整數用-1 03/22 14:39
20F:→ lycantrope: 排序就練不到for-loop 03/22 14:40
21F:→ lycantrope: 例:max(occurrences, key = lambda x:occurrences[x]) 03/22 14:42
原來如此
感謝各位大大解惑
※ 編輯: i329 (36.235.193.17 臺灣), 03/22/2022 18:28:05
22F:推 poototo: 有興趣可以去看資料結構的排序與搜尋 03/22 23:45
23F:→ poototo: 程式語言的內建方法都是包裝過的API 03/22 23:46
好的 我再努力
24F:推 aalexx: 拿紙筆一步一步跟著程式手動執行,把每一步都寫下來 03/23 02:27
我遇到一個問題 有些寫法看不懂 又沒辦法打開一個一個看 該怎麼辦呢@@
※ 編輯: i329 (36.235.165.174 臺灣), 03/24/2022 22:50:08
25F:→ aalexx: 什麼叫打開一個一個看?你知道問題,你知道別人的答案,你 03/26 16:48
26F:→ aalexx: 還需要什麼? 03/26 16:48
就是有時候看不懂得出的結果怎麼來的 或是為什麼自己寫的無法運行 這樣
※ 編輯: i329 (36.235.187.113 臺灣), 03/28/2022 23:10:44
27F:→ mantour: 你可以試著用看看可以設定斷點或是逐步執行的debug工具 04/02 17:47