:1.787KB : :1 :2022-10-12 15:05:53
C++解方程(仅限加减)如果开发者对于本文件有需要的可以参考。
#include
#include
#include
using namespace std;
int t=0; //模拟题万年不变的冤大头存储变量t
double num,alphabet; //一个是等号一侧的(n),一个是另一侧(a)
char letter; //letter是该式子中的未知数
bool flag=0,f=1,fl=1; //flag记等式左右的,f记正负的,fl记是不是字母的系数
bool flag0=1; //flag0为记录t=0的时候系数是0还是-1或1的bool型变量
//上面给我的直接观感就是——我就像戏台上的将军:背上全是flag
int main()
{
char c;
while(cin>>c) //不停输入字符~~~
{
if(c>='0' && c<='9') //如果是数字~
{
t=t*10 int(c-'0'); //t前头挪一位,给新来的让地儿,加上这个新来的,就是现在的t
if(t==0) //判断:系数是真的0还是假的0
flag0=0;
}
if((c>='a' && c<='z') || (c>='A' && c<='Z'))//如果是字母
{
letter=c; //恭喜,我们找到了那个未知数!
// if(flag==0) 错误示范:不分类
// alphabet =t;
// else
// alphabet =-1*t;
if(t==0 && flag0==1) //判断a或-a的情况
{
// if(f==1)
t=1; //将t存为1
// else //错误示范:双重负号
// t=-1;
}
if(f==1) //系数是正的
{
if(flag==1) //在等号右边,移项变号
alphabet =-1*t;
else //等号左边不变
alphabet =t;
}
else //系数是负的
{
if(flag==1) //等号右边移项变号
alphabet =t;
else //左边不变
alphabet =-1*t;
}
// cout<
fl=0; //重置fl :D
flag0=1; //重置flag0 =D
}
// if(c=='=') 错误示范:符号判定提前
// { (哦对了,这处错我改了10分钟)
// flag=1;
// t=0;
// fl=1;
// }
// if(c=='-')
// {
// f=0;
// t=0;
// fl=1;
// }
// if(c==' ')
// {
// f=1;
// t=0;
// fl=1;
// }
if((c=='-' || c==' ' || c=='=') && fl==1)//如果这货真的只是一个数
{
if(f==0) //和前头正好相反的判定法,不用讲了
{
if(flag==1)
num =-1*t;
else
num =t;
}
else
{
if(flag==1)
num =t;
else
num =-1*t;
}
}
if(c==' ' || c=='-' || c=='=')//搞完一通之后重置t和fl
{
fl=1;
t=0;
}
if(c=='=') //等号,先把flag变一下,再默认等号后是正的
{
flag=1;
f=1;
}
if(c=='-') //负号,f变成0即可
f=0;
if(c==' ') //正号,f变成1即可
f=1;
// cout<
if(fl==1) //如果收尾没结束
{
if(f==0) //判——定——
num =-1*t;
else
num =t;
}
if(alphabet==0)
{
if(num==0)
{
cout<<"未知数可以等于任意数"<
}
else
{
cout<<"此方程无解"<
}
}
cout<
{
cout<<"0.000"<
}
printf("%.3lf",num/alphabet);
return 0; //并不完美的结束 ヽ(* ̄▽ ̄*)ノ
}
01-29算术表达式生成树,解方程,可扩展解方程组
10-19C++许可授权相关代码
11-19在excel进行加减乘除运算方法
11-14excel加减乘除用法介绍
11-09word实现一秒钟计算所有加减乘除
09-09C++建立重载函数sroot
09-07C++的string的实现源码分析
07-30C++14新特性所有知识点集合