1.题目
 2.思路
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的值直接在函数中就已经被更改。



















