c语言数组当中的一些算法
时间: 2023-11-24 18:50:27 浏览: 29
以下是几个常见的C语言数组算法:
1. 冒泡排序
冒泡排序是一种简单的排序算法,它重复地遍历要排序的数组,比较相邻的两个元素,如果顺序不对就交换它们。重复这个过程,直到整个数组都被排序。
```c
void bubbleSort(int arr[], int n) {
int i, j;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
```
2. 选择排序
选择排序是一种简单的排序算法,它的工作原理是每次从未排序的数组中选择最小的元素,将其放到已排序的数组的末尾。
```c
void selectionSort(int arr[], int n) {
int i, j, min_idx;
for (i = 0; i < n-1; i++) {
min_idx = i;
for (j = i+1; j < n; j++) {
if (arr[j] < arr[min_idx]) {
min_idx = j;
}
}
int temp = arr[i];
arr[i] = arr[min_idx];
arr[min_idx] = temp;
}
}
```
3. 插入排序
插入排序是一种简单的排序算法,它的工作原理是将未排序的元素插入到已排序的数组中的正确位置。
```c
void insertionSort(int arr[], int n) {
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j+1] = arr[j];
j = j - 1;
}
arr[j+1] = key;
}
}
```