一维数组插入排序
时间: 2023-07-02 09:14:33 浏览: 42
一维数组插入排序的实现思路如下:
1. 从第二个元素开始,将该元素插入到已排序的序列中,使得插入后仍然保持有序。
2. 对于每一个未排序的元素,在已排序的序列中从后往前扫描,找到相应的位置并插入。
以下是一维数组插入排序的示例代码(使用 C++ 语言实现):
```c++
void insertionSort(int arr[], int n) {
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
/* Move elements of arr[0..i-1], that are greater than key, to one position ahead of their current position */
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
```
在这个示例代码中,`arr` 是待排序的一维数组,`n` 是数组的大小。函数 `insertionSort` 实现了一维数组插入排序的算法。
相关问题
java一维数组选择排序
以下是两种Java一维数组选择排序的例子:
1. 冒泡排序
```java
public int[] sort(int[] a) {
int temp;
for(int i=0;i<a.length;i++){
for(int j=i+1;j<a.length;j++){
if(a[i]>a[j]){
temp=a[i];
a[i]=a[j];
a[j]=temp;
}
}
}
return a;
}
```
2. 插入排序
```java
public int[] sort(int[] a){
for(int i=0;i<a.length;i++){
for(int j=i;j>0;j--){
if(a[j-1]>a[j]){
swap(a,j-1,j);
}
}
}
return a;
}
public void swap(int[] arr,int i,int j){
arr[i]=arr[i]^arr[j];
arr[j]=arr[i]^arr[j];
arr[i]=arr[i]^arr[j];
}
```
利用java实现一维数组的插入排序
好的,下面是利用 Java 实现一维数组的插入排序的代码:
```java
public class InsertionSort {
public static void main(String[] args) {
int[] arr = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3};
insertionSort(arr);
System.out.println(Arrays.toString(arr));
}
public static void insertionSort(int[] arr) {
int n = arr.length;
for (int i = 1; i < n; i++) {
int key = arr[i];
int j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = key;
}
}
}
```
以上的代码中,我们定义了一个 `insertionSort` 函数,它接收一个一维数组 `arr` 作为参数。函数中的核心是一个 for 循环,它依次遍历数组中的每个元素。在遍历过程中,我们将当前元素的值赋值给变量 `key`,并将变量 `j` 初始化为当前元素的前一个位置。接着,我们使用一个 while 循环,将数组中比 `key` 大的元素向右移动一个位置,直到找到一个比 `key` 小的元素为止。最后,我们将 `key` 插入到该元素的右边。
最后,我们在 `main` 函数中定义了一个一维数组 `arr`,并调用 `insertionSort` 函数对它进行排序。最后输出排序后的数组。