信息学奥赛一本通 1910:【00NOIP普及组】计算器的改良 | 洛谷 P1022 [NOIP2000 普及组] 计算器的改良
生活随笔
收集整理的這篇文章主要介紹了
信息学奥赛一本通 1910:【00NOIP普及组】计算器的改良 | 洛谷 P1022 [NOIP2000 普及组] 计算器的改良
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
【題目鏈接】
ybt 1910:【00NOIP普及組】計算器的改良
洛谷 P1022 [NOIP2000 普及組] 計算器的改良
【題目考點】
1. 字符數組
2. 一元一次方程
3. 模擬
【解題思路】
例:2x + 1 = 3這個一元一次方程中,2是系數,x是未知數,1與3都是常數。
- 由于題目指定這是一元一次方程,而且除了未知數和系數間是乘法,其余只有加減法。考慮的情況比較簡單
- 將未知數與系數的乘積都移動到等號左邊,將常數都移動到等號右邊,經過加和運算后,一定可以形成ax = b的形式,其中a是系數,b是常數,x是未知數。下一步運算:x = b/a,即可得到方程的解。
- 在代碼中模擬上述求方程的過程即可。遍歷并解析公式字符串,遇到一個未知數項(一次項),就將其移動到等號左邊,系數加和。遇到一個常數項,就將其移動到等號右邊,常數加和。最后得到ax=b中的a和b,進而求出解。
【題解代碼】
解法1:模擬
#include<bits/stdc++.h> using namespace std; #define N 1005 int main() {char s[N], v;//s:公式字符串 v:未知數字母 cin >> s;int len = strlen(s), num = 0, sign = 1;//num:構造出的數字 sign:構造出的數字的符號 int ln = 0, rn = 0;//ln:等號左側未知數的系數和 rn:等號右側常數和 bool isLeft = true;//是否在遍歷等號左邊 for(int i = 0; i <= len; ++i)//遍歷包括最后的'\0' {if(s[i] >= '0' && s[i] <= '9')//如果是數字,則構造數字 num = num * 10 + s[i] - '0';else{if(s[i] >= 'a' && s[i] <= 'z')//如果是未知數 {v = s[i];//確定未知數字母 if(isLeft == false)//如果是右側的項,則移動到左側,系數符號改變 sign = -sign;ln += sign * num;//未知數系數增加sign*num }else//如果是常數項 {//如果s[i]是'\0'且最后一個字符是字母,那么會運行到這一句,此時num為0,不影響rn的值 if(isLeft)//如果是左側的項,移動到右側后系數符號改變 sign = -sign;rn += sign * num;//右側常數增加sign*num }sign = 1;//符號還原為正 num = 0;//構造數字變量歸0 if(s[i] == '-')//下一個數字符號位負 sign = -1;else if(s[i] == '=')//經過等號,后面就是等號右邊的式子了 isLeft = false;}}cout << v << '=' << fixed << setprecision(3) << (double)rn / ln;return 0; }總結
以上是生活随笔為你收集整理的信息学奥赛一本通 1910:【00NOIP普及组】计算器的改良 | 洛谷 P1022 [NOIP2000 普及组] 计算器的改良的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: taxtable java_C语言计算个
- 下一篇: linux中GIT组件,linux –