/**
* 功能:給定兩個排序後的數組A和B,其中A的末端有足夠的緩衝空間容納B。將B合併入A並排序。前端
*/數組
- /**
- * 問題:若是將元素插入數組A的前端,就必須將原有的元素向後移動,以騰出空間。
- * 思路:將元素插入數組A的末端。
- *
- * 注意:在處理完B的元素以後,不須要複製A的剩餘元素,由於那些元素本來就在A中。
- * @param a
- * @param b
- * @param lastA
- * @param lastB
- */
- public static void merge(int[] a,int[] b,int lastA,int lastB){
- int indexA=lastA-1;
- int indexB=lastB-1;
- int indexMerged=lastA+lastB-1;
-
- while(indexA>=0&&indexB>=0){
- if(a[indexA]>b[indexB]){
- a[indexMerged]=a[indexA];
- indexMerged--;
- indexA--;
- }else{
- a[indexMerged]=a[indexB];
- indexMerged--;
- indexB--;
- }
- }
-
- while(indexB>=0){
- a[indexMerged]=a[indexB];
- indexMerged--;
- indexB--;
- }
-
- }