实例介绍
【实例简介】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; //并不完美的结束 ヽ(* ̄▽ ̄*)ノ
}
相关软件
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论