- 1、本文档共9页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
一元高次方程C语言实现(最高五次)
一元高次方程c语言实现(windows VC6.0版本)
注意:如果在linux vine或者UNIX以及非windows的系统下运行的话将代码pow以及sqrt全部替换为powf和sqrtf
以下为代码
#includestdio.h
#includestdlib.h
#includemath.h
#includestring.h
#define MAX 1000/*最大递归次数为1000次*/
#define ERROR math error\n/*显示错误信息*/
char Fun3[10],fx5[10]=;/*美化输出结果*/
float a1,b1,c1,d1,e1,f1;/*宏定义高次方程各项系数最大五次*/
int NUMjdg;/*判断函数最高次数*/
float FC(float a,float b);/*解一元一次方程*/
float FC3(float a,float b,float c,float d);/*解一元三次方程*/
float FC2(float a,float b,float c,int num);/*解一元二次方程*/
float FC4(float a,float b,float c,float d,float e);/*解一元四次方程*/
float FC5();/*解一元五次方程*/
float fun(float x);/*五次函数代值求解*/
float dfun(float x);/*五次导函数代值求解*/
float iterate(float x);/*牛顿迭代法猜值求解*/
int main()
{
float x5;/*五次方程最后一个解*/
FILE *fp;/*解的内容以文件的形式保存*/
char save;
char buf[256];/*从文件内读取内容保存至buf*/
buf[0]=\0;/*防止乱码,开头定义为NULL*/
fp=fopen(fun.dat,w);
strcpy(Fun3,);
fclose(fp);
printf(Do you want to save the result? y or n);/*是否想保存结果数据?*/
printf(\n---);
scanf(%c,save);
redo:
printf(please input degree number\n---);/*请输入最高次数*/
scanf(%d,NUMjdg);
if(NUMjdg1||NUMjdg5) goto redo;
printf(the number of a?---);/*输入最高次项系数*/
scanf(%f,a1);
if(a1==0)
{printf(ERROR);return 1;}
printf(the number of b?---);/*输入第二高次项系数*/
scanf(%f,b1);
if(NUMjdg==1)
{printf(the result is %g\n,FC(a1,b1)); goto end1;}
printf(the number of c?---);/*输入第三高次项系数*/
scanf(%f,c1);
if(NUMjdg==2)
{FC2(a1,b1,c1,1); goto end2;}
printf(the number of d?---);/*输入第四高次项系数*/
scanf(%f,d1);
if(NUMjdg==3)
{FC3(a1,b1,c1,d1); goto end3;}
printf(the number of e?---);/*输入第五高次项系数*/
scanf(%f,e1);
if(NUMjdg==4)
{FC4(a1,b1,c1,d1,e1); goto end4;}
printf(the number of f?---);/*输入常数项系数*/
scanf(%f,f1);
x5=FC5();
end2:end4:
if(a1!=0) printf(\n********\nThere is following result:\n);
fp=fopen(fun.dat,r);
while(fgets(buf,256,fp)!=NULL)
{printf(%s,buf);}
fclose(fp); fp=fopen(fun.dat,a);
if(NUMjdg==5){
fprintf(fp,x%s=%g\n,fx5,x5);
printf(x%s=%g\n,fx5,x5);
}
您可能关注的文档
最近下载
- Roland罗兰乐器JUNO-Gi 带数字录音功能的便携合成器JUNO-Gi Workshop 04 Realtime Control in the JUNO-Gi支持文档.pdf
- 天正变频器TVFS9说明书.pptx VIP
- 人教版小学三年级上册语文期末.docx VIP
- SW7203数据手册_V13926596180高效率双向升降压.pdf VIP
- GB50070-2024-矿山电力设计规范.doc
- 学前教育_农村幼儿园户外游戏活动现状的调查研究.docx VIP
- 国开农村经济管理形考作业1-4试题及答案.pdf
- 嵌入式系统基础与实践基于ARMCortex-M3内核的STM32微控制器习题答案.pdf
- 学前教育_传统文化在幼儿园环境创设中应用现状调查.docx VIP
- 2024-2025学年人教版数学三年级上册期末测试卷.pdf VIP
文档评论(0)