C语言求一元二次方程的根,这题很简单嘛?看看这种想法很惊奇!

数学基础:一元二次方程

只含有一个未知数(一元),并且未知数项的最高次数是2(二次)的整式方程叫做一元二次方程。标准形式为:ax²+bx+c=0(a≠0)

求解公式:求根公式法

用求根公式法解一元二次方程的一般步骤为:

①把方程化成一般形式

0?wx_fmt=jpeg

,确定a,b,c的值(注意符号);

②求出判别式

0?wx_fmt=jpeg

的值,判断根的情况;

③在

0?wx_fmt=jpeg

(注:此处△读“德尔塔”)的前提下,把a、b、c的值代入公式

0?wx_fmt=jpeg

进行计算,求出方程的根。

于是得到C语言题的解法一:

0?wx_fmt=jpeg

这样的做法,很简单,我想学过C语言,稍微用点力 应该就是没有问题的。

惊奇的是小编想输入x^2+2x+1=0 的方式去做,意思是直接输入这样一个字符串的方式去求解,然后瞬间很多人直接懵逼了吧! 即运行结果需如下:

0?wx_fmt=jpeg

或者

0?wx_fmt=jpeg

这,是不是有点意思,有点难度?

0?wx_fmt=jpeg

惊奇解法

首先求根方式不变: 用函数进行封装

0?wx_fmt=jpeg

从上可以看出获取 a,b,c 才是关键,把问题转换为字符串处理

于是就有这样一个函数:int finStringA(char *str, int length, char *posStr,int posLength)

char *str: 被查询的字符串 int length:该字符串长度

char *posStr:目的字符串 int posLength:,目的字符串的长度

作用:查询x或者x^2 出现的位置,并返回

0?wx_fmt=jpeg

查找到相应字符串后,还需要返回a ,b, c等字符串于是有这样一个函数:

本来想用截取函数,懒得查找前一个位置,就自己写了个截取函数

void getCharABC(char *str, int length,int Pos,char *posStr,int& flag)

char *str:原字符串 int length:原字符串长度 int Pos :指定位置

char *posStr: 存储a,b,c int& flag:正负标记,(后面发现存在这样一个bug)

0?wx_fmt=jpeg


经过上面的函数处理后貌似得到的a和b以及c字符串是逆序的,所以又写了个逆转字符串函数

0?wx_fmt=jpeg

0?wx_fmt=jpeg

总结:

0?wx_fmt=jpeg

0?wx_fmt=gif

一个简单的题,基本上把字符串中的的很多函数都用上了,即提高了自己的能力,也复习了相关知识。
希望初学者对此有一个更加深刻一点的认识,不要拘泥于语法的限制,编程语言服务于编程思想。学到了真正的编程思想,才叫货真价实的懂编程。
不能为了做题而做题,要多思考,多变

0?wx_fmt=jpeg


  • 15
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值