C語言在一堆數字中求眾數的問題
書上的例題,輸入二十個任意數字,然後求出現最多的那個數字。看書上用mode來代表那個數的名稱,本來還不懂為啥用mode(模式?),後來查一下才知道mode也叫「眾數」,就是一組數字中最常出現的那個數字就叫mode(眾數 Mode 指一組數據中出現次數最多的變數值)。真長了知識。?:teeth
但這題真的是有看沒有懂,從oldcount=0;以下,看了一頭霧水。:crazyeyes:hitwall:collapse 代碼:
#include <stdio.h> |
想法是先假定定一個數字是眾數 mode=stats[0]; (還疑這裡寫錯)
然後去計算第一個數字在這20個數字中出現過幾次,然後去看是否會比 之前眾數次數還多(第一次一定會因為oldcount = 0),假若比之前還多 就把當下的count存入oldcount,然後把現在的數字存入oldmode, 大致上想法是這樣。 |
引用:
對於mode=stats[1]這裡,確實是我第一個不解之處,後來你說應是mode=stats[0]也覺得這樣才合理。 後來實際跑了一下,好像原本的寫法答案會出錯。:whoknows 所以應是state[0]才對。 |
另外 mode=stats[0]; 的未置可能也放錯
|
引用:
那本題應該如何寫才正確? 我剛才是有跑一次,得的答案是ok的。 |
引用:
就會發現書上的out put是2 但是正確答案應為 1 附上我的Code (其實效率不好XD) 代碼:
#include <stdio.h> |
thanks.:bow
我剛才再次拿mode=stats[1];和mode=stats[0];二個都去跑一次,這次果然二個全都是錯誤的結果,剛才我不知怎麼跑的?:shorto 謝謝你的code。 那如果是要修改原本的code,該如何改呢? 真奇怪,如果發生這麼多的錯誤,因為錯誤之處至少二個地方,這本書是如何通過校對的?我目前看的是這本 C語言自學手冊 第三版 ,但我買的比較早,封面不一樣。 跑了一下你的code,在include<iostream>那裡卡住,說沒有這個檔或目錄,後來我改成<iostream.h>也一樣。?:teeth 另外 using namespace std; 已經超出我目前看過的東西了。 補充,當我看到cin cout時我才想到您寫的是 c++,所以就存成.cpp再去跑,就ok了。~cici |
引用:
代碼:
#include <stdio.h> |
yes, it works!! many thanks.~yes
明天再來好好研究推敲一下。:whoknows |
|
所有時間均為 +8。現在的時間是 07:26 AM。 |
Powered by vBulletin® 版本 3.8.4
版權所有 ©2000 - 2024,Jelsoft Enterprises Ltd.