亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

攜帶另一個元素并打印出來

攜帶另一個元素并打印出來

慕沐林林 2022-11-02 16:59:37
瓷磚沒有澄清我的問題,所以這是我的程序的一部分:public static void selectionsort(int[] userID, double[] donation, PrintWriter output) {    int min, swap;    for (int i = 0; i < userID.length - 1; i++) {        min = i;        for (int m = i + 1; m < userID.length; m++) {            if (userID[m] < userID[i]) {                min = m;                swap = userID[min];                userID[min] = userID[i];                userID[i] = swap;            }        }        output.println(userID[i] + "   " + donation[i]);    }}我的數組如下:456             250.0123            175.34345            123.06但是當我的方法去output.println(userID[i]+"   "+donation[i]);它打印出來是這樣的:123   250.0345   175.34456   123.06我想保持身份證號碼和捐款的匹配。例如,456 應該始終與 250.00 相關聯,無論 456 移動到哪里。我如何解決它?
查看完整描述

1 回答

?
蝴蝶刀刀

TA貢獻1801條經驗 獲得超8個贊

問題是因為在該方法中,只有userID數組被排序,而donation數組沒有被相應地打亂。userID并且數組元素和數組元素之間沒有其他映射donation,因此兩個數組元素的打印都不會顯示先前的關聯。


因此,在您的方法中,每當您交換userID數組元素的位置時,您還必須交換相應donation數組元素的位置。這可以如下完成:


public static void selectionsort(int[] userID, double[] donation, PrintWriter output) {

    int min, swap;

    for (int i = 0; i < userID.length - 1; i++) {

        min = i;

        for (int m = i + 1; m < userID.length; m++) {

            if (userID[m] < userID[i]) {

                min = m;

                swap = userID[min];

                userID[min] = userID[i];

                userID[i] = swap;


                swap=donation[min];

                donation[min]=donation[i];

                donation[i]=swap;

            }

        }

        output.println(userID[i] + "   " + donation[i]);

    }

}


查看完整回答
反對 回復 2022-11-02
  • 1 回答
  • 0 關注
  • 107 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號