1.题目
2.思路
1.首先,我们可以知道,我们必须先要把z求出来,但这里需要注意的是x,y并不包含了全部的定义域,所以我们必须先判断是否输入的数据满足条件。而这,就是我们所需要突破的函数的防御,即如何使函数抵御不正确使用或非法数据传入时出错,提升健壮性?方法就是在函数的入口处,检查输入参数的合法性。
2.当然这里就又有一个问题了,即我们知道,一个函数的返回值只能有一个,如果你又想要返回函数输入值错误的判断,又想返回z值,这个时候便会无计可施。但是我们很巧的是可以发现z值都是正数,这也就意味着我们可以通过使z值为负来,执行后面的语句。(具体看代码)
3.子函数的实现
#include<stdio.h>
#include<math.h>
double func(double x, double y)
{double z=0;if (x < 0 && y < 0){z = exp(x + y);}else if (0 <= x && x < 1 && y >= 0){z = exp(2 * x - y);}else if (x >= 1){z = log(x);}else{z = -1;}return z;
}
(注意,这里的指数与对数,都需要math.h头文件,这个具体用法可以自己百度搜索)
4.主函数的实现
int main()
{double x, y,z;printf("请输入两组数字:(中间用空格隔开就行)\n");scanf_s("%lf %lf", &x, &y);double result = func(x, y);if (result == -1){printf("输入的数据不在定义域范围内\n");}else{double s;s = result + x + y;printf("结果为%lf", s);}return 0;
}
这里的result实际上便是z,当z等于负数,我们可以知道,用户输入的数据并不是在对应的范围内,所以我们可以通过这样的方法进行防御和函数的加固。
5.总结反思
那么问题又来了,如果z可以取负数,那么这样的话不就与之冲突了么,而且如果函数很复杂,我也不知道能不能取到呀。
这里我们就要认识形参与实参的关系了,形参是不能改变实参,但我们可以通过地址找到他,从而来更改,但目前地址还没学,我们可以使用一下引用,这个引用不等于形参,因为它是本来就是实参,只不过换了个名字而已,这样的话,我们就可以通过直接更改所引用的参数的值,然后至于函数可否运行,能不能实现,我们则用状态来判断,如-1和其他的数,接下来,我们具体看一下代码。
#include<stdio.h>
#include<math.h>
double func(double x, double y,double &z)
{double zz=0;if (x < 0 && y < 0){z = exp(x + y);}else if (0 <= x && x < 1 && y >= 0){z = exp(2 * x - y);}else if (x >= 1){z = log(x);}else{zz = -1;}return zz;
}int main(){double x, y;double z = 0;printf("请输入两组数字:(中间用空格隔开就行)\n");scanf_s("%lf %lf", &x, &y);double result = func(x, y, z);if (result == -1){printf("输入的数据不在定义域范围内\n");}else{double s;s = z + x + y;printf("结果为%lf", s);}return 0;}
这里我们使用了引用参数传参,用zz负责判断函数的可行性,z的值直接在函数中就已经被更改。