入门oj 1173: [Noip2000]计算器的改良

1173: [Noip2000]计算器的改良
Time Limit: 1 Sec Memory Limit: 128 MB
Submit: 86 Solved: 47
[Submit][Status][Web Board]
Description
NCL是一家专门从事计算器改良与升级的实验室,最近该实验室收到了某公司所委托
的一个任务:需要在该公司某型号的计算器上加上解一元一次方程的功能。实验室将这个任
务交给了一个刚进入的新手ZL先生。为了很好的完成这个任务,ZL先生首先研究了一些
一元一次方程的实例:
4+3x=8
6a-5+1=2-2a
-5+12Y=0
ZL先生被主管告之,在计算器上键入的一个一元一次方程中,只包含整数、小写字母
及十、一、=这三个数学符号(当然,符号"一"既可作减号,也可作负号)。方程中并没
有括号,也没有除号,方程中的字母表示未知数。
问题求解:
编写程序,解输入的一元一次方程,将解方程的结果(精确至小数点后三位)输出至屏幕。
你可假设对键入的方程的正确性的判断是由另一个程序员在做,或者说可认为键入的一
元一次方程均为合法的,且有唯一实数解。
Input
Output
Sample Input

6a-5+1=2-2a

Sample Output

a=0.750

模拟题,要知道等号作业的状态和符号的状态,分析好情况然后处理
Code:

#include<stdio.h>
#include<math.h>
#include<iostream>
#include<cmath>
#include<string>
#include<cstring>
using namespace std;

int main()
{
    char s[1005];
    cin>>s;
    int l=strlen(s);
    double xx=0,sum=0,abs=0;
    int t=1,f=1;
    char x;
    for(int i=0; i<l; i++)
    {
        if(s[i]>='0'&&s[i]<='9')
        {
            sum=sum*10+s[i]-'0';
        }
        else
        {
            if(s[i]>='a'&&s[i]<='z'||s[i]>='A'&&s[i]<='Z')
            {
                x=s[i];
                xx+=f*sum*t;
            }
            else
            {
                abs+=-1*f*sum*t;
                if(s[i]=='-')
                    t=-1;
                else
                    t=1;
                if(s[i]=='=')
                    f=-1;
            }
            sum=0;
        }
    }
    if(s[l-1]!=x)
        abs+=-1*sum*t*f;

    printf("%c=%.3lf\n",x,abs/xx);
    return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章