1.设计一个函数min(x, y),返回两个double类型值的较小值。在一个简单 的驱动程序中测试该函数
#include <stdio.h>
#include <stdlib.h>
double mix(double a, double b)
{
return a > b ? b : a;
}
int main(void)
{
double a, b;
scanf("%lf %lf", &a, &b);
printf("%lf\n", mix(a, b));
return 0;
}
2.编写并测试一个函数larger_of(),该函数把两个double类型变量的值替换为较大的值。例如, larger_of(x, y)会把x和y中较大的值重新赋给两个变量
#include <stdio.h>
#include <stdlib.h>
void large_of(double *a, double *b)
{
//------------------------------------------------------------------
//*a > *b ? *b = *a : *a = *b; 不可以这样写,会报错
//这段代码报错的原因是在 C 语言中,条件运算符 ?: 的结果必须是一个可修改的左值(即可以被赋值的变量)
//------------------------------------------------------------------
if (*a > *b) {
*b = *a; // 如果 *a 大于 *b,则将 *b 的值更新为 *a 的值
} else {
*a = *b; // 否则将 *a 的值更新为 *b 的值
}
}
int main(void)
{
double a, b;
scanf("%lf %lf", &a, &b);//注意参数是指针
large_of(&a, &b);
printf("%lf %lf\n", a, b);
return 0;
}
3. 编写并测试一个函数,该函数以3个double变量的地址作为参数,把最小值放入第1个变量,中间值放入第2个变量,最大值放入第3个变量
--------------------------------------------------------------
主要是"思路"以及对"三目运算符"的运用
--------------------------------------------------------------
#include <stdio.h>
void sort(double *x,double *y,double *z);
int main(){
double x,y,z;
printf("请输入三个数值: ");
scanf("%lf %lf %lf",&x,&y,&z);
sort(&x,&y,&z);
printf("x(最小值): %0.2lf y(中间值): %0.2lf z(最大值): %0.2lf",x,y,z);
return 0;
}
void sort(double *x,double *y,double *z){
double max,sort_one;
sort_one = *x;
max = *x > *y ? *x: *y,max = max > *z ? max : *z;
if(max == *x){
*x = *y > *z ? *z : *y;
*y = *y > *z ? *y : *z;
*z = max;
}
if(max == *y){
*x = *x > *z ? *z : *x;
*y = sort_one > *z ? sort_one : *z;
*z = max;
}
if(max == *z){
*x = *x > *y ? *y : *x;
*y = sort_one> *y ? sort_one : *y;
*z = max;
}
}