c语言函数编程
编写一函数实现用牛顿迭代法求方程ax的3次方+bx的平方+cx+d=0在x=1附近的一个实根.主函数完成各系数值的输入及所求得的根值的输出....
编写一 函数实现用牛顿迭代法求方程ax的3次方+bx的平方+cx+d=0在x=1附近的一个实根.主函数完成各系数值的输入及所求得的根值的输出.
展开
6个回答
展开全部
#include <stdio.h>
#include <math.h>
float solut(float a,float b,float c, float d)
{
float x=1,x0,f,f1;
do
{
x0=x;
f=((a*x0+b)*x0+c)*x0+d;
f1=(3*a*x0+2*b)*x0+c;
x=x0-f/f1;
}
while(fabs(x-x0)>-1e-3);
return(x);
}
main()
{
float a,b,c,d;
printf("\ninput a,b,c,d:");
scanf("%f,%f,%f",&a,&b,&c,&d);
printf("equation is:%5.2fx^3+%5.2fx^2+%5.2fx+%5.2f=0",a,b,c,d);
printf(\nx=%10.7\n",solut(a,b,c,d);
}
#include <math.h>
float solut(float a,float b,float c, float d)
{
float x=1,x0,f,f1;
do
{
x0=x;
f=((a*x0+b)*x0+c)*x0+d;
f1=(3*a*x0+2*b)*x0+c;
x=x0-f/f1;
}
while(fabs(x-x0)>-1e-3);
return(x);
}
main()
{
float a,b,c,d;
printf("\ninput a,b,c,d:");
scanf("%f,%f,%f",&a,&b,&c,&d);
printf("equation is:%5.2fx^3+%5.2fx^2+%5.2fx+%5.2f=0",a,b,c,d);
printf(\nx=%10.7\n",solut(a,b,c,d);
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
看看以下这个程序吧
/*----------用牛顿迭代法求解方程的根-----------*/
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#define LOWLIMIT 1.E-6
#define MAX 100
#define infinity 1.E300
double f(double x)
{
return x*x+3*x-3;/*依你的需要自定义修改函数*/
}
double diff(double x)
{
return 2*x+3; /*定义函数的导数*/
}
finite(double x)
{
if(x > infinity)return 0; /*此函数的功能是防止上溢*/
else return 1;
}
/*-------牛顿法迭代算法--------*/
void newton()
{
int k;
double x;
double delta_x;
printf("Enter x0,the initial guess:");
scanf("%lf",&x);
for(k=0;k<MAX;k++){
delta_x=-f(x)/diff(x);
if(!finite(delta_x))break;
x+=delta_x;
if(fabs(delta_x) < LOWLIMIT)break;
}
/*分析结果*/
if(k==MAX)
printf("\t No convergence in %d iterations.\n",MAX); /*与X轴无交点*/
else if(!finite(delta_x))
printf("\tOverflow on delta_x.\n");/*溢出*/
else
printf("\tProcess converged.\n"); /*与X轴有交点,成功求出根*/
printf("\tx=%e,delta_x=%e.\n",x,delta_x);
printf("f(x)=%e,f'(x)=%e.\n",f(x),diff(x));
}
void main()
{
int do_again;
puts("\n\n-------Solve f(x)=x^2+3x-3 by Newton's method.--------");
do{newton();
printf("\n\nEnter 1 to continue ,0 to exit:");
scanf("%d",&do_again);
}while(do_again);
}
/*----------用牛顿迭代法求解方程的根-----------*/
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#define LOWLIMIT 1.E-6
#define MAX 100
#define infinity 1.E300
double f(double x)
{
return x*x+3*x-3;/*依你的需要自定义修改函数*/
}
double diff(double x)
{
return 2*x+3; /*定义函数的导数*/
}
finite(double x)
{
if(x > infinity)return 0; /*此函数的功能是防止上溢*/
else return 1;
}
/*-------牛顿法迭代算法--------*/
void newton()
{
int k;
double x;
double delta_x;
printf("Enter x0,the initial guess:");
scanf("%lf",&x);
for(k=0;k<MAX;k++){
delta_x=-f(x)/diff(x);
if(!finite(delta_x))break;
x+=delta_x;
if(fabs(delta_x) < LOWLIMIT)break;
}
/*分析结果*/
if(k==MAX)
printf("\t No convergence in %d iterations.\n",MAX); /*与X轴无交点*/
else if(!finite(delta_x))
printf("\tOverflow on delta_x.\n");/*溢出*/
else
printf("\tProcess converged.\n"); /*与X轴有交点,成功求出根*/
printf("\tx=%e,delta_x=%e.\n",x,delta_x);
printf("f(x)=%e,f'(x)=%e.\n",f(x),diff(x));
}
void main()
{
int do_again;
puts("\n\n-------Solve f(x)=x^2+3x-3 by Newton's method.--------");
do{newton();
printf("\n\nEnter 1 to continue ,0 to exit:");
scanf("%d",&do_again);
}while(do_again);
}
参考资料: http://www1.blog.163.com/article/-OC4F-tDP1An.html
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
C语言中一个完整的函数由函数首部和函数体构成,而且定义函数时两者都是必不可少的。
函数定义的一般形式如下:
类型标识符 函数名(形参表列) // 这是函数首部
// 以下{ }内的是函数体
{
说明部分
执行部分
}
举例说明如下:
// 定义一个不带返回值的函数
// 函数功能:输出形参的值
void fun(int a, int b)
{
printf("%d, %d\n", a, b);
}
// 定义一个带返回值的函数
// 函数功能:返回2个整数数的最大值
int fun(int a, int b)
{
return a>b ? a : b;
}
函数定义的一般形式如下:
类型标识符 函数名(形参表列) // 这是函数首部
// 以下{ }内的是函数体
{
说明部分
执行部分
}
举例说明如下:
// 定义一个不带返回值的函数
// 函数功能:输出形参的值
void fun(int a, int b)
{
printf("%d, %d\n", a, b);
}
// 定义一个带返回值的函数
// 函数功能:返回2个整数数的最大值
int fun(int a, int b)
{
return a>b ? a : b;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
int
sum(int
n)
{
for(int
a=1,b=0;a<=n;a++)
{
b+=a;
}
return
b;
}
void
main()
{
int
n;
scanf("%d",&n);
printf("sum=%d\n",sum(n));
}
int
sum(int
n)
{
for(int
a=1,b=0;a<=n;a++)
{
b+=a;
}
return
b;
}
void
main()
{
int
n;
scanf("%d",&n);
printf("sum=%d\n",sum(n));
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
unsigned
int
sum(unsigned
int
n)
{
if
(n
<
0
)
return;
if(n==0
||
n==
1)
return
n;
else
return
sum(n-1)+n;
}
nt
main()
{
unsigned
int
n;
scanf("%d",
&n);
printf("%d",
sum(n));
return
0;
}
unsigned
int
sum(unsigned
int
n)
{
if
(n
<
0
)
return;
if(n==0
||
n==
1)
return
n;
else
return
sum(n-1)+n;
}
nt
main()
{
unsigned
int
n;
scanf("%d",
&n);
printf("%d",
sum(n));
return
0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询