用c语言编写定义一个具有10个容量的一维整数数组,并通过键盘输入10个任意整数,请采用交换排序法实现数组数据的由小到大的排序及输出
时间: 2024-03-14 08:44:59 浏览: 18
好的,下面是代码实现:
```c
#include <stdio.h>
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
void sort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = i + 1; j < n; j++) {
if (arr[i] > arr[j]) {
swap(&arr[i], &arr[j]);
}
}
}
}
int main() {
int arr[10];
printf("请输入10个整数:\n");
for (int i = 0; i < 10; i++) {
scanf("%d", &arr[i]);
}
sort(arr, 10);
printf("排序后的数组为:\n");
for (int i = 0; i < 10; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
运行结果:
```
请输入10个整数:
10 9 8 7 6 5 4 3 2 1
排序后的数组为:
1 2 3 4 5 6 7 8 9 10
```
希望能够帮到你!
相关问题
编写一个c语言程序,定义一个长度为10的一维整型数组,输入10个数据,利用函数完成选择排序
好的,以下是实现选择排序的C语言示例代码:
```c
#include <stdio.h>
void selectionSort(int arr[], int size){
for(int i=0; i<size-1; i++){
int minIndex = i;
for(int j=i+1; j<size; j++){
if(arr[j] < arr[minIndex]){
minIndex = j;
}
}
int temp = arr[i];
arr[i] = arr[minIndex];
arr[minIndex] = temp;
}
}
int main(){
int arr[10];
printf("请输入10个整数:\n");
for(int i=0; i<10; i++){
scanf("%d", &arr[i]);
}
selectionSort(arr, 10);
printf("排序后的结果为:\n");
for(int i=0; i<10; i++){
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
在上面的代码中,我们定义了一个名为 `selectionSort` 的函数,它接受一个整型数组和数组的大小作为参数,然后使用选择排序算法对数组进行排序。
在 `main` 函数中,我们首先输入10个整数,然后调用 `selectionSort` 函数对这些整数进行排序,并输出排序后的结果。需要注意的是,C语言中没有现成的 `swap` 函数,我们需要手动定义一个变量来交换数组中的两个元素。
如何用C语言实现输入一个3×3的二维整数矩阵,分别采用冒泡法、交换法编程实现对这9个数字从小到大进行排序,并输出。
以下是用冒泡法和交换法分别实现对9个数字从小到大排序的C语言代码:
冒泡法排序:
```c
#include <stdio.h>
void bubble_sort(int arr[], int n);
int main() {
int matrix[3][3];
printf("请输入一个3×3的整数矩阵:\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
scanf("%d", &matrix[i][j]);
}
}
int arr[9];
int k = 0;
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
arr[k++] = matrix[i][j];
}
}
bubble_sort(arr, 9);
printf("排序后的结果为:\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
printf("%d ", arr[i * 3 + j]);
}
printf("\n");
}
return 0;
}
void bubble_sort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
for (int 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;
}
}
}
}
```
交换法排序:
```c
#include <stdio.h>
void swap(int *a, int *b);
int main() {
int matrix[3][3];
printf("请输入一个3×3的整数矩阵:\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
scanf("%d", &matrix[i][j]);
}
}
int arr[9];
int k = 0;
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
arr[k++] = matrix[i][j];
}
}
// 交换法排序
for (int i = 0; i < 8; i++) {
for (int j = i + 1; j < 9; j++) {
if (arr[i] > arr[j]) {
swap(&arr[i], &arr[j]);
}
}
}
printf("排序后的结果为:\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
printf("%d ", arr[i * 3 + j]);
}
printf("\n");
}
return 0;
}
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
```