C语言数组排序方法?
C语言将数组元素大小排序方法: 以下使用的是冒泡排序法实线数组从小到大排序。 思想:每次相邻两个数比较,若升序,则将大的数放到后面,一次循环过后,就会将最大的数放在最后。
10、2、3、4、5、6、9、8、7、1是输入的待排序的数列,经过第一次排序,将最大的,10放在最后,第二次排序,将剩下的2、3、4、5、6、9、8、7、1进行冒泡,将当前最大的9放在倒数第二的位置,以此类推。 以下是具体代码:
#include
请教下用冒泡法对数组a进行由小到大的排序,怎样实现?
#include <stdio.h>int main(){int i,j,t,n,a[100];scanf("%d",&n); //共n个数for(i=0;i<n;i++) scanf("%d",&a[i])
; //读入for(i=0;i<n-1;i++) //冒泡排序 for(j=0;j<n-1-i;j++) if(a[j]>a[j+1]) {t=a[j];a[j]=a[j+1];a[j+1]=t;}for(i=0;i<n;i++) //输出 printf("%d ",a[i]);return 0;}
C语言,数组数据升序排列?
以下是C语言中对整型数组进行升序排列的示例代码,使用冒泡排序算法:
```c
#include <stdio.h>
void bubble_sort(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;
}
}
}
}
int main() {
int arr[] = {10, 3, 7, 1, 5};
int n = sizeof(arr) / sizeof(arr[0]);
int i;
printf("Original array: ");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
bubble_sort(arr, n);
printf("\nSorted array: ");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
在上面的代码中,`bubble_sort`函数使用冒泡排序算法对整型数组进行升序排列,而`main`函数则演示了如何使用该函数来对数组进行排序。该代码的输出为:
```
Original array: 10 3 7 1 5
Sorted array: 1 3 5 7 10
```
这表明,数组已按升序排列。