为了账号安全,请及时绑定邮箱和手机立即绑定

携带另一个元素并打印出来

携带另一个元素并打印出来

慕沐林林 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 关注
  • 74 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信