zoukankan      html  css  js  c++  java
  • 计算器的改良(纯字符串)o1

    原题传送门

    这题比较水,就是细节。。多了点。

    首先字符串要处理好(废话。。)

    基础不行的话要多去看看书。。

    然后捏,这题主要就是几个判断;

    当我们读字符,如果读到运算符号,那么就要停下来,把之前的常数存起来,当然,直接加也行。

    如果读到负号(b1),还有在等号右边时(b2),要取相反数 num=num*b1*b2;

    注意!字母之前可以没有数字!这是重点!

    下面贴代码

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    char s[105]; 
    char s1; 
    int ans[2];
    int main(){
        scanf("%s",s);
        s[strlen(s)]='+';
        int nq=0;int cs=0;
        int sum=0;
        int bl=1,bl2=1;
        for(int i=0;i<=strlen(s);i++)
        {
            char c;
            c=s[i];
            if(i==0)if(c>='a'&&c<='z') sum=1;
            if(c=='-'||c=='+'||c=='=')
            {
                if((s[i-2]=='-'||s[i-2]=='+'||s[i-2]=='=')&&(s[i-1]>='a'&&s[i-1]<='z'))sum=1;
                sum=sum*bl2*bl;
                if(s[i-1]>='a'&&s[i-1]<='z')
                {ans[0]+=sum;s1=s[i-1];} 
                else 
                ans[1]+=sum; sum=0;
                if(c=='-')
                bl=-1;else bl=1;
                if(c=='=') bl2=-1;    
            }
            else if(c>='0'&&c<='9')sum=sum*10+(c-'0');
        }    
        int tt1=0,tt2=0;
        double ansq=ans[1]*1.0/ans[0]; 
        printf("%c=%.3f",s1,-ansq);
    }
  • 相关阅读:
    ES6相关概念及新增语法
    正则表达式
    递归
    高阶函数和闭包
    严格模式
    this指向
    递归
    严格模式
    函数内部的this指向
    函数的定义和调用
  • 原文地址:https://www.cnblogs.com/ghostfly233/p/6840587.html
Copyright © 2011-2022 走看看