第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定

二路歸并

標(biāo)簽:
Java 算法
* 利用二路归并求两个数组合起来的中位数
* 求合并之后剔除重复元素
* 求两个数组的共同元素
public class MergeArr {
    public static void main(String[] args) {
        int[] a = {1, 2, 5, 6, 8, 9, 11};
        int[] b = {5, 6, 8, 9, 88};
        ArrayList arr = mergeArr(a, b);
        for (int i = 0; i < arr.size(); i++) {
            System.out.print(arr.get(i) + ",");
        }
        System.out.println();
        ArrayList deleteArr = deleteReprtition(arr);
        for (int i = 0; i < deleteArr.size(); i++) {
            System.out.print(deleteArr.get(i) + ",");
        }
        System.out.println();
        System.out.println(findMidNum(a, b));
        System.out.println();
        //获取共同元素
        ArrayList arrayList = mergeArr(a,b);
        ArrayList comArr = getCommonNum(arrayList);
        for (int i = 0; i < comArr.size(); i++) {
            System.out.print(comArr.get(i)+",");

        }
    }

    /**
     * 有序表的合并
     */
    public static ArrayList mergeArr(int[] a, int[] b) {
        int i = 0;
        int j = 0;
        ArrayList arr = new ArrayList<>();
        while (i < a.length && j < b.length) {
            if (a[i] < b[j]) {
                arr.add(a[i]);
                i++;
            } else {
                arr.add(b[j]);
                j++;
            }
        }
        //两个表
        while (i < a.length) {
            arr.add(a[i]);
            i++;
        }
        while (j < b.length) {
            arr.add(b[j]);
            j++;
        }
        return arr;
    }

    /**
     * 查两个有序表归并以后的中位数
     */
    public static int findMidNum(int[] a, int[] b) {
        int k = (a.length + b.length) % 2 == 0 ? (a.length + b.length) / 2 - 1 : (a.length + b.length + 1) / 2 - 1;
        int i = 0;
        int j = 0;
        int midNum = 0;
        while (i + j <= k) {
            if (a[i] < b[j]) {
                if (i + j == k) {
                    midNum = a[i];
                }
                i++;
            } else {
                if (i + j == k) {
                    midNum = b[j];
                }
                j++;
            }
        }
        return midNum;
    }
/**删除重复元素*/
    public static ArrayList deleteReprtition(ArrayList arr) {
        int i = 1;
        int n = arr.size() - 1;
        while (i < n) {
            if (arr.get(i - 1) == arr.get(i)) {
                arr.remove(i);
                n--;
            } else {
                i++;
            }
        }
        return arr;
    }
/**获取公共元素*/
    public static ArrayList getCommonNum(ArrayList arr) {
        int i = 1;
        int n = arr.size() - 1;
        ArrayList comArr = new ArrayList();
        while (i < n) {
            if (arr.get(i - 1) == arr.get(i)) {
                comArr.add(arr.remove(i));
                n--;
            } else {
                i++;
            }
        }
        return comArr;
    }
}


點擊查看更多內(nèi)容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評論
感謝您的支持,我會繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學(xué)

大額優(yōu)惠券免費領(lǐng)

立即參與 放棄機會
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號

舉報

0/150
提交
取消