0916编译原理第二次上机作业
#include<stdio.h>

void Fenxi(a,b);
int i;
main(){
    char a[50];
    printf("请输入源程序:");
    gets(a);
    printf("您要分析的源程序为:");
    printf("%s",a);
    printf("\n");
    for(i=0;i<50;i++)
    {
        Fenxi(a[i],a[i+1]);
    }
    printf("\n");
}

void Fenxi(a,b)
{
    switch(a){
        case'+':
            printf("(13,+)");
            break;
        case'-':
            printf("(14,-)");
            break;
        case'*':
            printf("(15,*)");
            break;
        case'/':
            printf("(16,/)");
            break;
        case':':
            if(b=='=')
            {
                i++;
                printf("(18,:=)");
            }
            else
                printf("(17,:)");
            break;
        case'<':
            if(b=='>')
            {
                i++;
                printf("(21,<>)");
            }
            else if(b=='=')
            {
                i++;
                printf("(22,<=)");
            }
            else
                printf("(20,<)");
            break;
        case'>':
            if(b=='=')
            {
                i++;
                printf("(24,>=)");
            }
            else
                printf("(23,>)");
            break;
        case'=':
            printf("(25,=)");
            break;
        case';':
            printf("(26,;)");
            break;
        case'(':
            printf("(27,()");
            break;
        case')':
            printf("(28,))");
            break;
        case'#':
            printf("(20,#)");
            break;
        default:
            break;
    }
}

 

相关文章:

  • 2022-02-23
  • 2021-08-02
  • 2021-07-24
  • 2021-10-01
  • 2022-01-23
  • 2021-10-13
  • 2021-12-29
  • 2021-08-26
猜你喜欢
  • 2021-07-26
  • 2021-09-03
  • 2022-01-29
  • 2021-09-23
  • 2021-10-17
相关资源
相似解决方案