用二分法求下面方程在(-10,10)之间的根:2x^3-4x^3+3x-6=0

程序代码:#include<stdio.h>

#include<stdlib.h>

#include<math.h>

#define N 50 //二分次数

double fun(double x1, double x2) {

int count = 0;

double f1, f2, fm, mid;

while (1) {

f1 = 2 * pow(x1, 3) - 4 * pow(x1, 3) + 3 * x1 - 6;

f2 = 2 * pow(x2, 3) - 4 * pow(x2, 3) + 3 * x2 - 6;

if (f1 * f2 > 0) {

return 0;

}

++count;

mid = (x1 + x2) / 2;

fm = 2 * pow(mid, 3) - 4 * pow(mid, 3) + 3 * mid - 6;

if (fm * f1 == 0 || fm * f2 == 0 || count == N) {//循环终止条件,(找出根的准确值或者已达二分次数)

break;

}

if (fm * f1 < 0) {

x2 = mid;

}

else if (fm * f2 < 0) {

x1 = mid;

}

}

return mid;

}

void main() {

int x1 = -10;

int x2 = 10;

if (fun(x1, x2) != 0) {

printf("方程2x^3 - 4x^3 + 3x - 6 = 0在区间(%d,%d)之间的根为:%f\n", x1, x2, fun(x1, x2));

}

else {

printf("方程2x^3 - 4x^3 + 3x - 6 = 0在区间(%d,%d)之间无根\n",x1, x2);

}

system("pause");

}

  • 25
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值