C_and_CPP 板


LINE

開發平台(Platform): (Ex: Win10, Linux, ...) win7 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) code::block 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...) 不清楚XD 問題(Question): 先抱歉程式有點冗長不好看,非資工系,最近開始看資結寫C 寫merge sort,跑出來結果與預期不同 不確定是邏輯與觀念錯誤,還是code寫法的問題 餵入的資料(Input): int numbers[SIZE]={4,15,16,50,8,43,42,108}; 預期的正確結果(Expected Output): {4,8,15,16,42,43,50,108} 錯誤結果(Wrong Output): {4,15,16,50,8,43,42,108} 跟輸入一樣沒變 i,j,k那邊改成 int i=0; int j=0; int k=0; 又會跑出不同的結果 程式碼(Code):(請善用置底文網頁, 記得排版,禁止使用圖檔) #include <stdio.h> #include <stdlib.h> #define SIZE 8 int merge(int L[],int R[],int A[]){ int i=0; int j=0; int k=0; while( i<sizeof(L)/sizeof(L[0]) && j<sizeof(R)/sizeof(R[0])){ if(L[i] <= R[j]){ A[k] = L[i]; i++; } else{ A[k] = R[j]; j++; } k++; } while(i<sizeof(L)/sizeof(L[0])){ A[k]=L[i]; i++; k++; } while(j<sizeof(R)/sizeof(R[0])){ A[k]=R[j]; j++; k++; } } int merge_sort(int array[],int n){ if (n < 2){ return; } int mid = n/2; int left[mid]; int right[n-mid]; for (int i = 0; i < mid-1; i++){ left[i] = array[i]; } for (int i = mid; i < n-1; i++){ right[i-mid] = array[i]; } merge_sort(left,mid); merge_sort(right,n-mid); merge(left,right,array); } int main(void) { int numbers[SIZE]={4,15,16,50,8,43,42,108}; printf("\n"); for (int i = 0; i < SIZE; i++){ printf("%i ",numbers[i]); } printf("\n"); merge_sort(numbers,SIZE); for (int i = 0; i < SIZE; i++){ printf("%i ",numbers[i]); } printf("\n"); } 補充說明(Supplement): 無 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.160.149.180
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1540222486.A.CC2.html
1F:→ c910335: 大概是因為你誤解 sizeof 了 10/23 00:28
2F:→ c910335: https://ideone.com/XusuuF 10/23 00:29
3F:推 LPH66: 用 sizeof 求陣列長度只在你這變數真的是個陣列時有用 10/23 01:38
4F:→ LPH66: 你這裡傳進函數之後它就 decay 成指標了, 所以不能使用 10/23 01:38
5F:→ LPH66: (是的, 雖然是寫 [] 但骨子裡它依然只是一個指標) 10/23 01:38
6F:→ LPH66: C 的陣列沒有自帶長度資訊, 要求長度要嘛另外傳要嘛學字串 10/23 01:40
7F:→ LPH66: 你這裡另外傳會比較容易一點 10/23 01:40
瞭解了 謝謝! ※ 編輯: wavek (1.160.149.180), 10/23/2018 21:26:26







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燈, 水草

請輸入看板名稱,例如:e-shopping站內搜尋

TOP