基本信息
源码名称:C++解方程(仅限加减)
源码大小:3.36KB
文件格式:.cpp
开发语言:C/C++
更新时间:2021-12-18
   源码介绍

C 解方程(仅限加减)

#include<iostream>
#include<cmath>
#include<algorithm>
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<<c<<' '<<alphabet<<' '<<t<<endl; 
t=0; //重置t,返璞归真 XD 
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<<c<<' '<<t<<' '<<f<<' '<<alphabet<<' '<<num<<endl;
}
if(fl==1) //如果收尾没结束 
{
if(f==0) //判——定—— 
num =-1*t;
else
num =t;
}
if(alphabet==0)
{
if(num==0)
{
cout<<"未知数可以等于任意数"<<endl;
return 0;
}
else
{
cout<<"此方程无解"<<endl; 
return 0;
}

cout<<letter<<'='; //平平无奇大输出 
if(num/alphabet==0)
{
cout<<"0.000"<<endl;
return 0;
}
printf("%.3lf",num/alphabet);
return 0; //并不完美的结束 ヽ(* ̄▽ ̄*)ノ 
}