zoukankan      html  css  js  c++  java
  • uva 327 Evaluating Simple C Expressions

    //难得的1Y,完全水过去,硬生生地把式子搞出来,代码写得很差,但是数据较小而且判断

    //较多所以省去不少时间

    #include <stdio.h>
    #include <string.h>
    #include <algorithm>
    #define MAX 150
    using namespace std;
    char string[150],temp[150];
    struct elemt
    {
        char ch;
        int data;
        int flag;
    }a[MAX];  //flag=0表示这个元素在运算结束之后不需要变化,1表示运算后加1,-1表示运算后减1,所以同意+flag即可
    int cmp(struct elemt a , struct elemt b)
    {
        return a.ch<b.ch;
    }
    int main()
    {
        int i,j,len,value;  char ch;
        while(1)
        {
            for(i=j=0;1;i++)
            {
                if( (ch=getchar())==EOF )  return 0;
                if( ch=='\n')  break;
                temp[i]=ch;
                if(ch==' ') continue;
                else        string[j++]=ch;
            }
            temp[i]='\0'; string[j]='\0';
            printf("Expression: %s\n",temp); // printf("%s\n",string);
            
            len=strlen(string);
            for(j=0,i=0; j<len; )
            {
                if(string[j]==' ') {j++; continue;}
    
                if(string[j]>='a'  && string[j]<='z')
                {
                    if(j+2<len)
                    {
                        if( string[j+1]=='+' && string[j+2]=='+')
                        {  a[i].ch=string[j]; a[i].data=a[i].ch-'a'+1; a[i].flag=1;  i++; j+=3;  }
                        else if(string[j+1]=='-' && string[j+2]=='-')
                        {  a[i].ch=string[j]; a[i].data=a[i].ch-'a'+1; a[i].flag=-1; i++; j+=3;  }
                        else if( (string[j+1]=='+' || string[j+1]=='-') && (string[j+2]=='+' || string[j+2]=='-') )
                        { a[i].ch=string[j]; a[i].data=a[i].ch-'a'+1; a[i].flag=0; i++; a[i].ch=string[j+1]; 
    a[i].data=0; a[i].flag=0; i++; j+=2; }
                        else  // 字母,符号,字母
                        { a[i].ch=string[j];    a[i].data=a[i].ch-'a'+1; a[i].flag=0; i++; a[i].ch=string[j+1]; 
     a[i].data=0; a[i].flag=0; i++;j+=2; }
                    }
                    else  //倒数第一或者倒数第二个字母;或倒数第一则好帮,若是倒数第2,其实是不可能的,因为当前的是字母
                    {a[i].ch=string[j]; a[i].data=a[i].ch-'a'+1; a[i].flag=0; i++; j++;} 
                }
                else  //当前的的是符号
                {
                    if(j+2<len)  //后面还有足够的位置
                    {
                        if(string[j]=='+' && string[j+1]=='+' && string[j+2]>='a' && string[j+2]<='z')
                        { a[i].ch=string[j+2]; a[i].data=a[i].ch-'a'+1+1; a[i].flag=0; i++; j+=3; }
                        else if(string[j]=='-' && string[j+1]=='-' && string[j+2]>='a' && string[j+2]<='z')
                        { a[i].ch=string[j+2]; a[i].data=a[i].ch-'a'+1-1; a[i].flag=0; i++; j+=3; }
                        else if( (string[j]=='+' || string[j]=='-') && (string[j+1]=='+' || string[j+1]=='-') && 
    (string[j+2]=='+' || string[j+2]=='-'))
                        { a[i].ch=string[j]; a[i].data=0; a[i].flag=0; i++; j++; }
                        else if( (string[j]=='+' || string[j]=='-' ) && (string[j+1]=='+' || string[j+1]=='-') && 
    string[j+2]>='a' && string[j+2]<='z') 
                        //当前的和后面一位都是符号但是不同
                        {a[i].ch=string[i]; a[i].data=0; a[i].flag=0; i++; j++;}
                        else if( (string[j]=='+' || string[j]=='-' ) && string[j+1]>='a' && string[j+1]<='z')
                        {a[i].ch=string[j]; a[i].data=0; a[i].flag=0; i++;  j++; }
                    }
                    else  //倒数第1位或者倒数第二位,倒数第一位是不可能的
                    {a[i].ch=string[j]; a[i].data=0; a[i].flag=0; i++; j++;}
                }
            }
            len=i;
    //        for(len=i,i=0; i<len; i++) printf("%c",a[i].ch);  printf("\n");
    //        for(len=i,i=0; i<len; i++) printf("%c  %d  %d\n",a[i].ch , a[i].data , a[i].flag);
            for(value=a[0].data,i=1; i<len; )
            {
                if(a[i].ch=='+') value=value+a[i+1].data;
                else             value=value-a[i+1].data;
                i+=2;
            }
            printf("    value = %d\n",value);
            sort(a , a+len , cmp); 
            for(i=0; i<len; i++) if(a[i].ch>='a' && a[i].ch<='z')  break;
            for(; i<len; i++)
                printf("    %c = %d\n",a[i].ch , a[i].data+a[i].flag);
        }
        return 0;
    }
  • 相关阅读:
    MYSQL学习(二)
    Nginx学习总结(一)
    关于微服务架构的个人理解(一)
    深入理解Java虚拟机(二) : 垃圾回收
    深入理解Java虚拟机(一) 运行时数据区划分
    多线程系列之 线程安全
    多线程系列之 java多线程的个人理解(二)
    多线程系列之 Java多线程的个人理解(一)
    Java基础04—字符串
    Java基础03—流程控制
  • 原文地址:https://www.cnblogs.com/scau20110726/p/2712630.html
Copyright © 2011-2022 走看看