C程序设计 (第四版) 谭浩强 习题4.11
习题 4.11 输入4个整数,要求按由小到大的顺序输出。
IDE工具:VS2010
Note: 使用不同的IDE工具可能有部分差异。
代码块
方法1:使用数组和循环结构
#include <stdio.h>
#include <stdlib.h>
int main(){
int n[4], i, j, t;
printf("Please enter 4 numbers: ");
for (i = 0; i < 4; scanf("%d", &n[i]), i++); //输入4个整数
//对4个整数进行从小到大排序
for (i = 0; i < 4; i++)
for (j = i+1; j < 4; j++)
n[i]>n[j] ? t=n[i], n[i]=n[j], n[j]=t : n[i]=n[i], n[j]=n[j];
for (i = 0; i < 4; printf("%d ", n[i]), i++); //输出4个整数
printf("\n");
system("pause");
return 0;
}
方法2:使用函数的模块化设计
#include <stdio.h>
#include <stdlib.h>
#define N 4 //定义整数个数,可调整
#define FORMAT "%d" //定义输出格式符,可调整对应类型
typedef int Type; //定义数据类型模板,可调整
//输入数字
void inputNumbers(Type *arr, int n){
printf("Enter %d numbers: ", n);
for(int i = 0; i < n; i++){
scanf_s(FORMAT, &arr[i]);
}
}
//排序函数
void sort(Type *arr, int n){
int temp;
for(int i = 0; i < n - 1; i++){
for(int j = i + 1; j < n; j++){
if(arr[i] > arr[j]){
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
}
//输出排序后的结果
void outputNumbers(Type *arr, int n){
printf("Final Output: ");
for(int i = 0; i < n; i++){
printf(FORMAT, arr[i]);
printf(" ");
}
printf("\n");
}
int main(){
int *arr = (int*)malloc(N * sizeof(int));
inputNumbers(arr, N);
sort(arr, N);
outputNumbers(arr, N);
free(arr);
system("pause");
return 0;
}