关于排序算法中交换两个数

昨天写排序算法的时候遇到一个问题:将交换两个数的几句代码定义成一个静态方法,需要交换数字的时候调用这个方法,结果排序出来的结果是不对的。

代码如下:
public class Sort {

    public static void main(String[] args) {
        int[] arr = {10,9,8,7,6,5,4,3,2,1};
        maoPao(arr);
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + "-");
        }
    }

    public static void maoPao(int[] a) {
        for (int i = 0; i < a.length - 1; i++) {
            for (int j = 0; j < a.length - 1 - i; j++) {
                if (a[j] > a[j + 1]) {
                    swap(a[j], a[j+1]);
                }
            }
        }
    }
    public static void swap(int a, int b){
        a = a ^ b;
        b = a ^ b;
        a = a ^ b;
    }
}
输出结果如下:
输出结果

可以看到数组的顺序并没有改变
我们再将交换的代码写到里面去

public static void maoPao(int[] a) {
    for (int i = 0; i < a.length - 1; i++) {
        for (int j = 0; j < a.length - 1 - i; j++) {
            if (a[j] > a[j + 1]) {
                a[j] = a[j] ^ a[j + 1];
                a[j + 1] = a[j] ^ a[j + 1];
                a[j] = a[j] ^ a[j + 1];
            }
        }
    }
}
输出结果:
输出结果

这样是可以的

具体是什么原因我还不清楚,有待进一步研究,猜测是跟数组有关。有了解的朋友欢迎讨论。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,603评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 9,098评论 0 15
  • 排序的基本概念 在计算机程序开发过程中,经常需要一组数据元素(或记录)按某个关键字进行排序,排序完成的序列可用于快...
    Jack921阅读 5,362评论 1 4
  • 每天“❤️”时间 入睡前,静心安坐一会,让疲累的心休息片刻。可以在头脑里如放电影般过滤一天的过程,保持一份觉知,没...
    谷应阅读 1,504评论 0 0
  • 我一直婉拒别人的情意,只为个不确定的你。
    踏荫阅读 1,207评论 0 4

友情链接更多精彩内容