C语言的编程题:输入三个整数,按从大到小的顺序输出

求高手解答哪个才是对的啊... 求高手解答
哪个才是对的啊
展开
 我来答
小耳朵爱聊车
高粉答主

推荐于2019-09-13 · 说的都是干货,快来关注
知道大有可为答主
回答量:7378
采纳率:100%
帮助的人:299万
展开全部

#include <stdio.h>

main() 

int x,y,z,t; 

scanf("%d%d%d",&x,&y,&z); 

if (x<y) 

{t=x;x=y;y=t;} 

if(x<z) 

{t=z;z=x;x=t;} 

if(y<z) 

{t=y;y=z;z=t;} 

printf("%d %d %d\n",x,y,z); 

}

扩展资料:

使用三元运算符,这个运算符会使程序进一步简化,而且看起来更加的直观。

它的一般形式如下:

表达式1? 表达式2:表达式3;

? 表达式的值是由 表达式1 决定的。如果 表达式1 为真,则计算表达式2 的值,结果即为整个 ? 表达式的值。如果 表达式1 为假,则计算 表达式3 的值,结果即为整个 ? 表达式的值。

程序如下:

#include<stdio.h>

int main()

{

int max;

int a,b,c;

printf("请输入三个数:");

scanf("%d %d %d",11&a,&b,&c);

max=a>b?a:b;

max=c>max?c:max;

printf("Max is %d",max);

return 0; 

}

参考资料来源:百度百科-C语言

TableDI
2024-07-18 广告
Excel一键自动匹配,在线免费vlookup工具,3步完成!Excel在线免费vlookup工具,点击93步自动完成vlookup匹配,无需手写公式,免费使用!... 点击进入详情页
本回答由TableDI提供
小舅舅有点帅
推荐于2019-09-08 · TA获得超过1万个赞
知道答主
回答量:0
采纳率:0%
帮助的人:0
展开全部

参考代码:

#include "stdio.h"

int main()

{

int x,y,z,max,min;

scanf("%d%d%d",&x,&y,&z);

if(x>y){

max=x;

min=y;

}

if(z>max) max=z;

if(min>z) min=z;

y=x+y+z-max-min;

x=max;

z=min;

printf("从大到小排序:%d %d %d\n",x,y,z);

}

/*

运行结果:

3 1 2

从大到小排序:3 2 1

*/

扩展资料

利用指针变量,用函数实现将3个整数按从大到小的顺序输出。

解:程序:

#include<stdio.h>

void swap(int *ptr1, int *ptr2)

{

int temp = *ptr1;

*ptr1 = *ptr2;

*ptr2 = temp;

}

void exchange(int *q1, int *q2,int *q3)

{

void swap(int *ptr1, int *ptr2);

if (*q1 < *q2)

{

swap(q1, q2);

}

if (*q1 < *q3)

{

swap(q1, q3);

}

if (*q2 < *q3)

{

swap(q2, q3);

}

}

int main()

{

void exchange(int *q1, int *q2, int *q3);

int *p1, *p2, *p3, a, b,c;

printf("please enter three integer numbers:");

scanf("%d,%d,%d",&a,&b,&c);

p1 = &a;

p2 = &b;

p3 = &c;

exchange(p1, p2, p3);

printf("The order is:%d,%d,%d\n",a,b,c);

return 0;

}

结果:

please enter three integer numbers:7,-9,666

The order is:666,7,-9

请按任意键继续. . .

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
985967518
推荐于2017-09-10 · 知道合伙人教育行家
985967518
知道合伙人教育行家
采纳数:18027 获赞数:109858
14年本科毕业于河南理工大学,至今就读于河南理工大学攻读硕士学位,从事编程学习已有5年。

向TA提问 私信TA
展开全部

问题:输入三个数x,y,z,把其中的最大值赋值给x,中间赋值给y,最小值赋值给z。

参考代码:

#include "stdio.h"
int main()
{
int x,y,z,max,min;
scanf("%d%d%d",&x,&y,&z);
if(x>y){
max=x;
min=y;
}
if(z>max) max=z;
if(min>z) min=z;
y=x+y+z-max-min;
x=max;
z=min;
printf("从大到小排序:%d %d %d\n",x,y,z);       
}
/*
运行结果:
3 1 2
从大到小排序:3 2 1
*/
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cade007
2009-12-09 · TA获得超过232个赞
知道小有建树答主
回答量:203
采纳率:0%
帮助的人:250万
展开全部
路过这里,看了下,反正正好闲着,我也临时写下,并且编译一下,准确无误,每个必要的代码处我都加了解释,想必阁下是可以看懂的。希望对你有所帮助。

----------^--------------------------------^---------------------------------
#include<stdio.h>
void sort(int array[],int n);
void main(){
int num[100];
int i;
int n=3;//其实如果你这里n不定义大小,再修改下代码可以比较N个数了。
printf("请输入三个整数(将会按照从大到小的顺序输出): \n");
//输入三个数字
for(i=0;i<n;i++){
scanf("%d",&num[i]);
}
//调用sort函数
sort(num,n);
printf("按照从大到小的顺序输出: \n");
//输出排序后的数字
for(i=0;i<n;i++){
printf("%d \t",num[i]);
}
printf("\n");
}
void sort(int array[],int n){
int i,j;// 定义用于For循环用的
int replace,swap;//定义用来调用i和交换数字的变量
/*
下面的有点繁杂,其实稍微看下,就是用来从遍历数组中的数字(通过For循环来遍历),
从中随便选取两个数字,然后比较,如果前一个数字小于后一个数字,则通过变量swap
交换出来。
*/
//第一个For用来在数组中遍历n-1个数字
for(i=1;i<n;i++){
replace=i;
//第二个For用来在数组中遍历n-1前面的数字
for(j=i-1;j<n-1;j++){
if(array[j]<array[replace]){
replace=j;
}
if(replace!=i){
swap=array[i];
array[i]=array[replace];
array[replace]=swap;
}
}
}
}
----------^--------------------------------^---------------------------------

经过Bcc5.5编译器编译,得出:

----------^--------------------------------^---------------------------------
请输入三个整数(将会按照从大到小的顺序输出):
20 40 30
按照从大到小的顺序输出:
40 30 20
请按任意键继续. . .
----------^--------------------------------^---------------------------------
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
沐星辰曦
高粉答主

推荐于2019-09-22 · 关注我不会让你失望
知道小有建树答主
回答量:3779
采纳率:100%
帮助的人:105万
展开全部

#include <stdio.h>
int main()
{
int a,b,c,t;
scanf("%d%d%d",&a,&b,&c);
if(a<b){

t=a;a=b;b=t; 

}

if(b<c){ 

t=b;b=c;c=t;
}
printf("%d%d%d",a,b,c);
return 0;
}

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(10)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式