首页 > 其他 > 详细

洛谷—— P1022 计算器的改良

时间:2017-10-24 23:58:53      阅读:395      评论:0      收藏:0      [点我收藏+]

 P1022 计算器的改良

题目背景

NCL是一家专门从事计算器改良与升级的实验室,最近该实验室收到了某公司所委托的一个任务:需要在该公司某型号的计算器上加上解一元一次方程的功能。实验室将这个任务交给了一个刚进入的新手ZL先生。

题目描述

为了很好的完成这个任务,ZL先生首先研究了一些一元一次方程的实例:

4+3x=8

6a-5+1=2-2a

-5+12y=0

ZL先生被主管告之,在计算器上键入的一个一元一次方程中,只包含整数、小写字母及+、-、=这三个数学符号(当然,符号“-”既可作减号,也可作负号)。方程中并没有括号,也没有除号,方程中的字母表示未知数。

你可假设对键入的方程的正确性的判断是由另一个程序员在做,或者说可认为键入的一元一次方程均为合法的,且有唯一实数解。

输入输出格式

输入格式:

 

一个一元一次方程。

 

输出格式:

 

解方程的结果(精确至小数点后三位)。

 

输入输出样例

输入样例#1: 复制
6a-5+1=2-2a
输出样例#1: 复制
a=0.750

 

一道大模拟的题、、很简单,然而wa了好几遍、、、

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 1000
using namespace std;
char ch,s[N];
int f=1,y=1,k,b,sum;
int main()
{
    cin>>s;
    int l=strlen(s);
    for(int i=0;i<l;i++)
    {
        if(s[i]==-) f=-1,sum=0;
        if(s[i]==+) f=1,sum=0;
        if(s[i]>=a&&s[i]<=z) ch=s[i],sum=0;
        if(s[i]>=0&&s[i]<=9)
        {
            sum+=s[i]-0;
            if(s[i+1]>=a&&s[i+1]<=z) k+=y*f*sum;
            else if(s[i+1]>=0&&s[i+1]<=9) sum*=10;
            else b+=-y*f*sum;
        }
        if(s[i]===) y=-1,sum=0,f=1;        
    }
    double ans=1.0*b/k;
    printf("%c=%.3lf",ch,ans);
    return 0;
}

 

 

               技术分享

 

 

 

                      距 NOIp2017 还剩 17 天

 

                                你可以做的事情还有很多,即使到最后一秒也不要放弃,因为不到结束的那一刻谁也不知道结果会怎样

洛谷—— P1022 计算器的改良

原文:http://www.cnblogs.com/z360/p/7726234.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!