【C++】编写一个用二分法解方程的通用函数,并对下列方程求解。 1+x+x^3=0 Sin(x)-x=0

#include <iostream>
#include <math.h>
using namespace std;
int main()
{
	int k;
	double m, n;
	double i, sum;
	double eps = 1e-6;
	double a, b, c, d;
	double f1, f2;
	double * p=&i;
	cout << "求解形如ax^3+bx^2+cx+d=0方程请输入1\n求解形如asin(x)+bx=0输入2" << endl;
	cin >> k;
	
	if (k == 1)
	{
		cout << "输入a,b,c,d" << endl;
		cin >> a >> b >> c >> d;
		cout << "输入m,n" << endl;
		cin >> m >> n;
		f1 = a * pow(m, 3) + b * pow(m, 2) + c * m + d;
		f2 = a * pow(n, 3) + b * pow(n, 2) + c * n + d;
		if (f1 * f2 < 0)
		{
			while (fabs(m - n) > eps)
			{
				i = (m + n) / 2;
				sum = a * pow(i, 3) + b * pow(i, 2) + c * i + d;
				if (fabs(sum) < eps)
				{
					cout << "该方程的近似解" << *p;
					break;
				}
				else if (sum * f2 < 0)
				{
					m = *p;
				}
				else if (f1 * sum < 0)
				{
					n = *p;
				}
			}
		}
		else
		{
			cout << "该区间内无解!";
		}
		
	}
	else
	{
		cout << "输入a,b" << endl;
		cin >> a >> b;
		cout << "输入m,n" << endl;
		cin >> m >> n;
		f1 = a *sin(m) + b *m  ;
		f2 = a * sin(n) + b * n ;
		if (f1 * f2 < 0)
		{
			while (fabs(m - n) > eps)
			{
				i = (m + n) / 2;
				sum = a * sin(i) + b * i;
				if (fabs(sum) < eps)
				{
					cout << "该方程的近似解" << *p;
					break;
				}
				else if (sum * f2 < 0)
				{
					m =*p;
				}
				else if (f1 * sum < 0)
				{
					n =*p;
				}
			}
		}
		else
		{
			cout << "该区间内无解!";
		}
		
	}
	return 0;
}

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

忘川Lethe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值