题目如下:直接贴图片了(考研党时间有限,哈哈)
思路:
1、看到k后面r和s大小不同,对应不同的表达式,所以要用到if语句
2、由于多次出现sinx,所以把sinx功能封装
3、实现sinx函数,其实主要就是想办法实现sinx的表达式,这就是sinx的泰勒展开公式,找规律,可以发现:
每一项的表达式,后一项比前一项的区别在于:
1. 分子每次多乘2次x。
2. 分母每次阶乘都比前面多二个,多的就是比前面大1和大2的那二个数
#include<iostream>
#include <cmath>
using namespace std;
const double value = 1e-10;
//sin函数的实现sinx=x-x^3/3!+x^5/5!-x^7/7!+.......
double tsin(double x) {
double sum = 0;
double t = x;
int n = 1;
do{
sum= sum + t;//结果累加
n++;//迭代变量
//每一项的表达式,后一项比前一项的区别在于:
//1、分子每次多乘2次x。2、分母每次阶乘都比前面多二个,多的就是比前面大1和大2的那二个数
t = -t * x * x / (2 * n - 1) / (2 * n - 2);
} while (fabs(t)>=value);
return sum;
}
int main() {
double k, r, s;
cout << "r = ";
cin >> r;
cout << "s= ";
cin >> s;
if (r * r <= s * s) {
k = sqrt(tsin(r) * tsin(r) +tsin(s)*tsin(s));
}
else
{
k = tsin(r*s)/2;
}
cout << k << endl;
return 0;
}
验证一下:sin20大概是0.91,一半大概就是0.456,结果正确