C_and_CPP 板


LINE

不預先將陣列排序的話,大概就是 O(n) 以下提供一個 C 的版本: #include <assert.h> #include <stddef.h> // Yet another linear search. #define max(sz, arr, out) do { \ if (sz <= 1) { \ out = arr[0]; \ break; \ } \ out = arr[0]; \ size_t i; \ for (i = 1; i < sz; i++) { \ out = arr[i] > out ? arr[i] : out; \ } \ } while (0); int main(void) { int arr_i[] = {4, 2, 5, 1, 3}; int max_i; max(5, arr_i, max_i); assert(max_i == 5); float arr_f[] = {2.2, 3.3, 1.1, 5.5, 4.4}; float max_f; max(5, arr_f, max_f); assert(max_f == 5.5); return 0; } 這是寫好玩的,考試不要這樣寫,這樣只是在搞自己 有寫過一些 C 的就知道原因 ※ 引述《freexq (快樂蕃茄)》之銘言: : 題目:5個數字取最大值 : 貢獻三種寫法,希望有人能貢獻更多寫法 : 根據以往寫程式的經驗,一個題目不會只有一種解法 : 資料結構也許不同以外,程式流程(演算法)也不同 : 以下我的 : 第一種解法是手刻 : 第二種解法是利用sort()函式排列由小至大,然後取最大數 : 第三種解法是偷吃步,直接呼叫max_element()函式 : 基本上作業或考試應該用第一種手刻 : 而第二、三種寫法應該是自己開發程式情況下,直接取適合函式出來用 : 優點是比較不容易出錯,而且更節省時間 : 自己手刻則不一定一次到位,可能要test或debug。 : 以下是程式碼 : (一) : #include <iostream> : using namespace std; : int main() : { : int num[5],max; : //輸入五個整數至陣列num[] : cout<<"請輸入5個數字"<<endl; : for(int i=0;i<5;i++) : cin>>num[i]; : //逐一和整個陣列比較,取最大 : max=num[0]; : for(int i=1;i<5;i++) : { : if(num[i]>max) : max=num[i]; : } : //輸出最大數 : cout<<"\n最大數為 "<<max<<endl; : return 0; : } : (二) : #include <iostream> : #include <algorithm> : using namespace std; : int main () : { : int num[5]; : //輸入5個int數字至num[] : cout<<"請輸入5個數字"<<endl; : for(int i=0;i<5;i++) : cin>>num[i]; : //開始排序,由小到大 : sort(num,num+5); : //輸出最大數 : cout<<"\n最大數為 "<<num[4]<<endl; : return 0; : } : (三) : #include <iostream> : #include <algorithm> //使用max_element()函數 : using namespace std; : int main() : { : int num[5]; : //輸入5個int數字至num[] : cout<<"請輸入5個數字"<<endl; : for(int i=0;i<5;i++) : cin>>num[i]; : //輸出最大數 : //注意max_element()函數傳回 指標 : cout<<"\n最大數為 "<<*max_element(num,num+5)<<endl; : return 0; : } --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 112.105.249.161
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1525965934.A.BB5.html







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BabyMother站內搜尋

TOP