java冒泡排序

[size=medium][b]今天看了移位运算的操作,于是想到冒泡排序也是要定义一个中间变量的,就拿来实验一下,做下记录。其实两种写法没什么区别,主要是练习一下位运算。如果想装X可以采用位运算的方式写一下。[/b][/size]
public int[] sortInt(int[] a) {
if (a != null) {
for (int i = 0; i < a.length - 1; i++) {// 控制排序的次数(n-1)次
for (int j = 0; j < a.length - i - 1; j++) {// 控制每次排序的个数,第一次需要全部比较,第二次要减少1依次类推
if (a[j] > a[j + 1]) {// 利用一个数的异或两次同一个数是他本身去交换数据,不用做中间变量。
a[j] ^= a[j + 1];//a[j] = a[j]^a[j+1]
a[j + 1] ^= a[j];//a[j+1] = a[j]^a[j+1]
a[j] ^= a[j + 1];//a[j] = a[j]^a[j+1]
/**
* 稍微解释一下
* 4^3^3 = 4 就是一个数异或两次同一个数,就是他本身
* a[j] = a[j]^a[j+1]
*
* a[j+1] = a[j]^a[j+1] (a[j]^a[j+1]^a[j+1]=a[j])将a[j]赋值给a[j+1]
*
* a[j]=a[j]^a[j+1] (a[j]^a[j+1]^a[j]=a[j+1])此时a[j+1]已经获得值为a[j]了
*/
}
}
}
}
return a;
}


[color=red][size=medium][b]下面这个是中间变量的。[/b][/size][/color]

public int[] sortIntTmp(int[] a) {
if (a != null) {
for (int i = 0; i < a.length - 1; i++) {// 控制排序的次数(n-1)次
for (int j = 0; j < a.length - i - 1; j++) {// 控制每次排序的个数,第一次需要全部比较,第二次要减少1依次类推
int tmp ;
if (a[j] > a[j + 1]) {// 利用一个数的异或两次同一个数是他本身去交换数据,不用做中间变量。
tmp = a[j];
a[j] = a[j+1];
a[j+1] = tmp;
//这种方式看起来比较明了。
}
}
}
}
return a;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值