编写输入四个整数,按由小到大顺序输出C语言的编程
时间: 2023-04-05 18:03:35 浏览: 157
我可以回答这个问题。您可以使用C语言的if语句和比较运算符来实现这个功能。以下是一个示例代码:
#include <stdio.h>
int main() {
int a, b, c, d;
scanf("%d %d %d %d", &a, &b, &c, &d);
if (a > b) {
int temp = a;
a = b;
b = temp;
}
if (a > c) {
int temp = a;
a = c;
c = temp;
}
if (a > d) {
int temp = a;
a = d;
d = temp;
}
if (b > c) {
int temp = b;
b = c;
c = temp;
}
if (b > d) {
int temp = b;
b = d;
d = temp;
}
if (c > d) {
int temp = c;
c = d;
d = temp;
}
printf("%d %d %d %d", a, b, c, d);
return 0;
}
相关问题
4、c语言编程实现:键盘输入任意的四个整数,输出最大值和最小值,以 及从小到大顺序排列输出。
在C语言中,你可以使用`scanf`函数从键盘获取输入,然后通过比较运算符找出最大值和最小值,最后利用数组或循环来排序并输出结果。这里是一个简单的示例程序:
```c
#include <stdio.h> // 引入stdio库,用于输入输出
int main() {
int a, b, c, d; // 定义四个整型变量
printf("请输入四个整数:\n"); // 提示用户输入
// 获取用户输入,并检查是否成功
if (scanf("%d %d %d %d", &a, &b, &c, &d) != 4) {
printf("输入错误,只接受四个整数。\n");
return 1;
}
// 找出最大值和最小值
int max = a > b ? (a > c ? a : c) : (b > c ? b : c);
int min = a < b ? (a < c ? a : c) : (b < c ? b : c);
// 输出最大值和最小值
printf("最大值是:%d\n", max);
printf("最小值是:%d\n", min);
// 按顺序输出其他两个数字
int temp;
if (a <= b && a <= c) { // 如果a是最小的,交换a和min
temp = a;
a = min;
min = temp;
} else if (b <= a && b <= c) { // 否则,如果b是最小的
temp = b;
b = min;
min = temp;
}
if (c <= a && c <= b) { // 如果c是最小的
temp = c;
c = min;
min = temp;
}
if (a == b && a == c) { // 如果a、b、c相等,则输出它们
printf("剩下两个数字是:%d 和 %d\n", a, b);
} else if (a == b) { // 若a和b相等,c单独输出
printf("剩下两个数字是:%d 和 %d\n", a, c);
} else { // 其他情况,按升序输出
printf("剩下两个数字是:%d 和 %d\n", b, c);
}
return 0;
}
```
这个程序首先读取用户的四个整数,然后分别找到最大值和最小值,接着对剩余的两个数进行排序并输出。注意,在实际编写过程中,可以使用更简洁的方式处理相等的情况。
编程实现:输入四个整数,选择不同选项,完成对应的功能要求,并输出计算的结果。 (1)当输入1时,四个数按照从大到小输出; (2)当输入2 时,四个数按照从小到大输出; (3)当输入 3 时,统计出四个数中奇数和偶数的个数c语言实现
为了实现这个功能,你可以使用C语言编写一个程序,如下所示:
```c
#include <stdio.h>
// 函数原型声明
void sort(int a[], int n, int order);
int count_odd_even(int arr[], int n);
int main() {
int num[4], choice;
// 输入四个整数
printf("请输入四个整数:");
for (int i = 0; i < 4; i++) {
scanf("%d", &num[i]);
}
// 用户选择排序或计数
printf("请选择操作(1-排序,2-升序,3-统计):");
scanf("%d", &choice);
switch (choice) {
case 1: // 从大到小排序
sort(num, 4, 1);
printf("从大到小的顺序:\n");
for (int i = 0; i < 4; i++) {
printf("%d ", num[i]);
}
break;
case 2: // 从小到大排序
sort(num, 4, 0); // 使用默认降序
printf("从小到大的顺序:\n");
for (int i = 0; i < 4; i++) {
printf("%d ", num[i]);
}
break;
case 3: // 统计奇偶数
int odd_count = count_odd_even(num, 4);
printf("\n奇数有 %d 个,偶数有 %d 个\n", odd_count, 4 - odd_count);
break;
default:
printf("无效的选择!\n");
break;
}
return 0;
}
// 冒泡排序函数,order=1表示降序,order=0表示升序
void sort(int a[], int n, int order) {
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if ((order == 1 && a[j] > a[j + 1]) || (order == 0 && a[j] < a[j + 1])) {
int temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}
}
// 计算数组中奇数和偶数的数量
int count_odd_even(int arr[], int n) {
int odd_count = 0;
for (int i = 0; i < n; i++) {
if(arr[i] % 2 == 0) {
odd_count++;
} else {
odd_count--;
}
}
return odd_count;
}
```
运行此程序后,根据用户输入的选择,将完成相应的功能并显示结果。
阅读全文