3.输入N个正整数,要求输出从小到大排序后的结果。 (分别用选择排序和冒泡排序实现)
时间: 2023-03-26 13:03:31 浏览: 88
选择排序实现:
#include <stdio.h>
void selection_sort(int arr[], int n) {
int i, j, min_idx;
for (i = ; 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[min_idx];
arr[min_idx] = arr[i];
arr[i] = temp;
}
}
int main() {
int n, i;
scanf("%d", &n);
int arr[n];
for (i = ; i < n; i++) {
scanf("%d", &arr[i]);
}
selection_sort(arr, n);
for (i = ; i < n; i++) {
printf("%d ", arr[i]);
}
return ;
}
冒泡排序实现:
#include <stdio.h>
void bubble_sort(int arr[], int n) {
int i, j;
for (i = ; i < n-1; i++) {
for (j = ; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main() {
int n, i;
scanf("%d", &n);
int arr[n];
for (i = ; i < n; i++) {
scanf("%d", &arr[i]);
}
bubble_sort(arr, n);
for (i = ; i < n; i++) {
printf("%d ", arr[i]);
}
return ;
}
阅读全文