swap函数实现Java插入排序
时间: 2023-09-05 12:12:55 浏览: 123
以下是Java插入排序的swap函数实现:
```java
public static void swap(int[] arr, int i, int j) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
```
该函数接收一个整型数组arr,以及两个整数i和j作为参数。它会将arr[i]和arr[j]的值进行交换,从而实现交换操作。在Java中,数组是引用类型,因此在该函数中直接修改数组元素的值可以影响到调用该函数的代码中的数组。
相关问题
swap实现Java插入排序
以下是使用swap实现Java插入排序的示例代码:
```
public static void insertionSort(int[] arr) {
for (int i = 1; i < arr.length; i++) {
for (int j = i; j > 0; j--) {
if (arr[j] < arr[j - 1]) {
swap(arr, j, j - 1);
}
}
}
}
public static void swap(int[] arr, int i, int j) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
```
在插入排序中,我们将数组分为已排序和未排序两部分。对于每个未排序的元素,我们将其插入到已排序部分的正确位置,以此完成排序。在上面的代码中,我们使用了两个嵌套循环来实现插入排序。外部循环迭代未排序部分的元素,内部循环则从当前元素开始向前比较,直到找到正确的插入位置。
在内部循环中,我们使用了swap函数来交换两个元素的位置。如果当前元素比前一个元素小,则交换它们的位置,以此将当前元素插入到正确的位置。这个过程一直持续到当前元素被插入到已排序部分为止。
最终,当外部循环结束时,整个数组就被排序完成了。
JAVA编写一个函数,给定一个int型数组,实现插入排序,快速排序算法
当然可以。在Java中,我们可以分别编写插入排序和快速排序算法。
1. **插入排序** (Insertion Sort):
```java
public class InsertionSort {
public static void insertionSort(int[] arr) {
for (int i = 1; i < arr.length; i++) {
int key = arr[i];
int j = i - 1;
// 将大于key的元素向右移动
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = key;
}
}
public static void main(String[] args) {
int[] array = {9, 5, 2, 7, 1};
insertionSort(array);
for (int num : array) {
System.out.print(num + " ");
}
}
}
```
2. **快速排序** (Quick Sort):
```java
public class QuickSort {
public static void quickSort(int[] arr, int low, int high) {
if (low < high) {
int pivotIndex = partition(arr, low, high);
quickSort(arr, low, pivotIndex - 1); // 对左半部分递归排序
quickSort(arr, pivotIndex + 1, high); // 对右半部分递归排序
}
}
private static int partition(int[] arr, int low, int high) {
int pivot = arr[high]; // 最后一个元素作为基准
int i = low - 1;
for (int j = low; j < high; j++) {
if (arr[j] <= pivot) {
i++;
swap(arr, i, j);
}
}
swap(arr, i + 1, high);
return i + 1;
}
private static void swap(int[] arr, int i, int j) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
public static void main(String[] args) {
int[] array = {9, 5, 2, 7, 1};
quickSort(array, 0, array.length - 1);
for (int num : array) {
System.out.print(num + " ");
}
}
}
```
这两个函数分别实现了插入排序和快速排序的基本思想。你可以根据需要选择其中一个来使用。
阅读全文