【題目描述】
NCL是一家專門從事計算器改良與升級的實驗室,最近該實驗室收到了某公司所委托的一個任務:需要在該公司某型號的計算器上加上解一元一次方程的功能。實驗室將這個任務交給了一個剛進入的新手ZL先生。為了很好的完成這個任務,ZL先生首先研究了一些一元一次方程的實例:
4+3x=8
6a-5+1=2-2a
-5+12Y=0
ZL先生被主管告之,在計算器上鍵入的一個一元一次方程中,只包含整數、小寫字母 及十、一、=這三個數學符號(當然,符號“一”既可作減號,也可作負號)。方程中並沒有括號,也沒有除號,方程中的字母表示未知數。
【輸入】
輸入一個一元一次方程,可認為輸入的一元一次方程均為合法的,且有唯一實數解。
【輸出】
將解方程的結果(精確至小數點后三位)輸出。
【輸入樣例】
6a-5+1=2-2a
【輸出樣例】
a=0.750
轉載自:[NOIP2000] 提高組 洛谷P1022 計算器的改良 - SilverNebula - 博客園
https://www.cnblogs.com/SilverNebula/p/5954915.html
1 /*by SilverN*/ 2 #include<algorithm> 3 #include<iostream> 4 #include<cstring> 5 #include<cstdio> 6 #include<cmath> 7 using namespace std; 8 int n,f; 9 int side; 10 int num; 11 char s[500]; 12 char tar; 13 int main(){ 14 int x=0,f=1; 15 side=1; 16 scanf("%s",s); 17 char ch; 18 int len=strlen(s); 19 s[len]='+'; 20 for(int i=0;i<=len;i++){ 21 ch=s[i]; 22 if( (ch<'0' || ch>'9' ) ){ 23 if(ch<'a' || ch>'z'){ 24 num+=-1*x*f*side; 25 x=0; f=1; 26 } 27 } 28 if(ch>='a' && ch<='z'){ 29 tar=ch; 30 if(!x)x=1;x=x*f*side; 31 n+=x; 32 x=0;f=1; 33 continue; 34 } 35 if(ch>='0' && ch<='9'){ 36 x=x*10+ch-'0'; 37 continue; 38 } 39 if(ch=='='){side=-1;continue;}//等號以后的項要變號 40 if(ch=='-'){f=-1;continue;} 41 if(ch=='+'){f=1;continue;} 42 } 43 double ans=(double)num/(double)n; 44 if(ans==-0)ans=0; 45 printf("%c=%.3f\n",tar,ans); 46 return 0; 47 }