攜程-合并數(shù)組中的中位數(shù)-java

![](http://ovteww5gs.bkt.clouddn.com/17-9-21/21

image.png

531353.jpg)

package xiecheng;

import java.util.Scanner;

public class midNum {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();// 第一個數(shù)組的元素個數(shù)
        int[] arr1 = new int[n];
        for (int i = 0; i < n; ++i) {
            arr1[i] = sc.nextInt();
        }
        int m = sc.nextInt();// 第二個數(shù)組的元素個數(shù)
        int[] arr2 = new int[m];
        for (int i = 0; i < m; ++i) {
            arr2[i] = sc.nextInt();
        }
        double res = middleNumberOfTwoArr(arr1, arr2);
        System.out.println(res);
    }

    private static int middleNumberOfTwoArr(int[] arr1, int[] arr2) {

        int start1 = 0;
        int start2 = 0;
        int end1 = arr1.length - 1;
        int end2 = arr2.length - 1;

        int midIndex1;
        int midIndex2;

        while (start1 < end1 || start2 < end2) {
            midIndex1 = (start1 + end1) / 2;
            midIndex2 = (start2 + end2) / 2;
            if (arr1[midIndex1] == arr2[midIndex2]) {
                return arr1[midIndex1];
            }

            if (arr1[midIndex1] < arr2[midIndex2]) {
                if (((end1 - start1) % 2 == 0) && ((end2 - start2) % 2 == 0)) {
                    start1 = midIndex1;
                    end2 = midIndex2;
                } else {
                    start1 = midIndex1 + 1;
                    end2 = midIndex2;
                }
            } else {
                if (((end1 - start1) % 2 == 0) && ((end2 - start2) % 2 == 0)) {
                    start2 = midIndex2;
                    end1 = midIndex1;
                } else {
                    start2 = midIndex2 + 1;
                    end1 = midIndex1;
                }
            }
        }
        if (arr1[start1] < arr2[start2]) {
            return arr1[start1];
        }else if (arr1[start1] > arr2[start2]) {
            return arr2[start2];
        }else {
            return (arr1[start1]+arr2[start2])/2;
        }
    }
}

提交結(jié)果;
14%
參考:
http://blog.csdn.net/huberjobs/article/details/51102970

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容