我只是想知道当代码选择,插入,冒泡返回void时此代码仍然有效。 是因为这些方法是静态的还是什么?
另外,如何在没有XOR的情况下交换变量?
public class Sorts {
static int[] a = { 100, 90, 70, 60, 50, 40, 30, 20, 10, 7, 6, 5, 4, 3, 2, -1 };
public static void main(String[] args) {
// TODO Auto-generated method stub
bubbleSort(a);// Worst one
print(a);
int[] b = {100, 90, 70, 60, 50, 40, 30, 20, 10, 7, 6, 5, 4, 3, 2, -1};
MY_SEMI_SELECTION_Sort(b);
print(b);
int[] e = { 100, 90, 70, 60, 50, 40, 30, 20, 10, 7, 6, 5, 4, 3, 2, -1};
selectionSort2(e);
print(e);
int[] c = {100, 90, 70, 60, 50, 40, 30, 20, 10, 7, 6, 5, 4, 3, 2, -1};
insertionSort(c); // The best so far
print(c);
}
static void insertionSort(int[] arr) {
int len = arr.length;
for (int i = 1; i < len; ++i) {
int j = i;
while (j > 0 && arr[j] < arr[j - 1]) {
// Swap
arr[j] ^= arr[j - 1] ^= arr[j];
arr[j - 1] ^= arr[j];
--j;
}
}
}
static void MY_SEMI_SELECTION_Sort(int[] arr) {
int len = arr.length;
for (int i = 0; i < len; ++i) {
for (int k = i; k < len - 1; ++k) {
if (arr[i] > arr[k + 1]) {
// Swapping........
arr[i] ^= arr[k + 1] ^= arr[i];
arr[k + 1] ^= arr[i];
}
}
}
}
static void selectionSort2(int[] arr) {
int len = arr.length;
for (int i = 0; i < len; ++i) {
int k;
int minIndex = i;
for (k = i; k < len - 1; ++k) {
if (arr[minIndex] > arr[k + 1]) {
minIndex = k + 1;
}
}
if (arr[minIndex] != arr[i]) {
arr[minIndex] ^= arr[i] ^= arr[minIndex];
arr[i] ^= arr[minIndex];
}
}
}
static void bubbleSort(int[] arr) {
int len = arr.length;
for (int i = 0; i < len; ++i) {
for (int k = 0; k < len - 1; ++k) {
if (arr[k] > arr[k + 1]) {
// Swapping........
arr[k] ^= arr[k + 1] ^= arr[k];
arr[k + 1] ^= arr[k];
}
}
}
}
static void swap(int a, int b) {
int temp = b;
b = a;
a = temp;
}
static void print(int[] arr) {
int len = arr.length;
for (int i = 0; i < len; ++i) {
System.out.print(arr[i] + " ");
}
System.out.println();
}
}
答案 0 :(得分:2)
为什么我的方法即使返回无效也能正常工作?
Java始终是按值传递的。但我们谈论的是什么价值?传递给函数的值是引用值,想象它就像数组所在的地址一样。因此,您总是在方法的内部和外部引用相同的数组。
如何在没有Xoring的情况下交换元素?
将变量想象为存储桶,您不能在不丢失其先前内容的情况下填充一个变量。您需要使用临时变量
int a=1,b=2;
int tmp=a;
a=b; //without the previous line of code you'd have lost the value of 'a'
b=tmp;
答案 1 :(得分:-1)
是因为方法是STATIC 不,因为int数组a只是一个引用。在调用不同的方法时,相同的引用作为参数传递。如果int数组a是main的局部变量,那么结果也是一样的。
如何在不对其进行划分的情况下交换元素 交换变量的最佳方法是通过异或。
a = a ^ b;
b = a ^ b;
a = a ^ b;
另一种方法是使用临时变量。