C语言三个数排列大小的实现方法

2025-05-27 0 97

这个题简单,也有很多的方法,在这里我想用数学的方法解决排序问题。ps:本人是个学渣,程序写的不好,欢迎各位大神指点帮助。

梳理思路:

以1 2 3为例 先考虑我们所有的可能输入类型(这里不一一列举):1 2 3;3 2 1 ;2 1 3;1 1 1;1 2 2;1 2 1;整体的思路为输入三个数后,我们从中取两个数,在这两个数中选出最大的后将最大的数与第三个数做差比较这里请参考代码理解;

代码:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16
#include<stdio.h>

int comp(int x,int y)

{

return x>y?x:y;

}

int main()

{

int i,j,k;

int a,b,c;

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

j=comp(a,b);//j为两个数里最大的值

k=c;//a+b-j求的是a,b里比较小的那个数;

if(j-k<0){printf("%d %d %d",k,j,a+b-j);return 0;} //说明K最大按顺序输出就可以了1 2 3;2 2 3

if(j-k>=a+b-j){printf("%d %d %d",j,a+b-j,k);return 0;}//3 2 1

if(j-k<a+b-j){printf("%d %d %d",j,k,a+b-j);return 0;}// 3 2 3

}

总结:

其实这个代码本质也和用if语句比较大小排序差不多,只不过这里不需要每次都调用三个if语句,直接一条if语句便可输出答案效率更高一点。

以上这篇C语言三个数排列大小的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持快网idc。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 C语言三个数排列大小的实现方法 https://www.kuaiidc.com/74303.html

相关文章

发表评论
暂无评论