題目本身很簡單,但是有一個地方值得一記。
直覺性錯誤:
假設兩個列表的長度都是從0算起,一個長為m,一個長為n,則兩者長度之和是多少?直覺告訴你是m+n,但事實它是m+n+1。
void merge(int A[], int m, int B[], int n) { if(m==0) while(n) {A[n-1]=B[n-1];n--;} int i=m-1; int j=n-1; while(i!=-1 && j!=-1){ if(A[i]>=B[j]) A[i+j+1]=A[i--]; else A[i+j+1]=B[j--]; } if(i==-1){ while(j!=-1) {A[j]=B[j];j--;} } }