用c语言编写函数,对传送过来的三个数按由小到大的顺序排列,并通过形参传回调用函数。
时间: 2024-02-12 16:04:19 浏览: 31
可以使用冒泡排序的思想来编写这个函数,代码如下:
```c
void sort(int *a, int *b, int *c) {
int temp;
if (*a > *b) {
temp = *a;
*a = *b;
*b = temp;
}
if (*a > *c) {
temp = *a;
*a = *c;
*c = temp;
}
if (*b > *c) {
temp = *b;
*b = *c;
*c = temp;
}
}
```
在主函数中,可以这样调用该函数:
```c
int main() {
int a = 3, b = 1, c = 2;
sort(&a, &b, &c);
printf("%d %d %d\n", a, b, c);
return 0;
}
```
输出结果为:
```
1 2 3
```
相关问题
用C语言编写函数,对传送过来的三个数按由小到大的顺序排列,并通过形参传回调用函数。
好的,以下是用C语言编写的函数,可以对传递进来的三个整数按照由小到大的顺序进行排序,并将排序后的结果通过形参传递回调用函数。
```c
void sort(int *x, int *y, int *z) {
int temp;
if (*x > *y) {
temp = *x;
*x = *y;
*y = temp;
}
if (*y > *z) {
temp = *y;
*y = *z;
*z = temp;
}
if (*x > *y) {
temp = *x;
*x = *y;
*y = temp;
}
}
```
在这个函数中,我们使用了指针来传递三个整数的值。在函数内部,我们首先比较前两个整数的大小,并将它们按照由小到大的顺序进行交换。然后,我们再次比较第二个整数和第三个整数的大小,并将它们也按照由小到大的顺序进行交换。最后,我们再次比较前两个整数的大小,确保它们也按照由小到大的顺序排列。
下面是一个示例程序,演示如何调用这个函数并使用返回的结果:
```c
#include <stdio.h>
void sort(int *x, int *y, int *z);
int main() {
int a = 3, b = 2, c = 1;
printf("Before sorting: a = %d, b = %d, c = %d\n", a, b, c);
sort(&a, &b, &c);
printf("After sorting: a = %d, b = %d, c = %d\n", a, b, c);
return 0;
}
```
输出结果如下:
```
Before sorting: a = 3, b = 2, c = 1
After sorting: a = 1, b = 2, c = 3
```
在这个示例程序中,我们首先定义了三个整数a、b、c,并将它们分别赋值为3、2、1。然后,我们调用了sort函数,并将a、b、c的地址作为参数传递给函数。最后,我们输出了排序后的结果。
用C语言编写代码:编写函数,对传送过来的三个数按由小到大的顺序排列,并通过形参传回调用函数
的程序中。请问,你可以帮我编写这个函数吗?
可以的,下面是这个函数的代码:
```
void sort(int *a, int *b, int *c){
int temp;
if(*a>*b){
temp=*a;
*a=*b;
*b=temp;
}
if(*b>*c){
temp=*b;
*b=*c;
*c=temp;
}
if(*a>*b){
temp=*a;
*a=*b;
*b=temp;
}
}
```
使用方法示例:
```
#include <stdio.h>
void sort(int *a, int *b, int *c);
int main()
{
int a=50, b=20, c=30;
sort(&a,&b,&c);
printf("%d %d %d\n",a,b,c);
return 0;
}
```
输出结果是:20 30 50