编译原理去掉注释

#include"stdio.h"
#include"stdlib.h"
int main()
{
    FILE *fp1,*fp2, *fp3;
    char ch1,ch2,ch3,ch4;
    int  flag1=0, flag2 = 0, flag3 = 0, flag4 = 0, flag5 = 0;
    int i = 0;
    int flag6 = 0;

    if((fp1=fopen("input.cpp","r"))==NULL)  // input.cpp为任意带注释的C程序
    {
        printf("file cannot be opened\n");
        exit(1);
    }
    if((fp2=fopen("output.cpp","w"))==NULL) // ouput.cpp为去掉注释后的程序
    {
        printf("file cannot be writed\n");
        exit(1);
    }

    //ch1=fgetc(fp1);
    //printf("%c",ch1);

    //读取每一个字符,不是结尾的话就显示出来

    printf("处理前\n");
    while((ch1=fgetc(fp1))!=EOF)
    {
        printf("%c",ch1);

        if(ch1 == '/' && flag1 == 0  && flag5 == 0 && flag6 == 0)//第一次遇到的/
        {
            flag1 = 1;
            continue;
        }
        else if(ch1 == '/' && flag1 == 1 && flag6 == 0)// 第二次遇到的/ 因为flag1为1的前提是已经有了一个/
        {
            flag3 = 1;
            flag1 = 0;
            continue;
        }
        else if(ch1 == '*' && flag1 == 1 && flag6 == 0)   /* 第二次遇到的* */
        {
            flag4 = 1;
            flag1 = 0;
            continue;
        }
        else if(ch1 == '"'  && flag6 == 0)
        {
            flag6 = 1;
        }
        else if(ch1 == '"' && flag6 == 1)
        {
            flag6 = 0;
        }
        if(flag3 == 1) // 两个/ 的情况
        {
            if(ch1 != '\n')  // 不是回车就跳过
            {
                continue;
            }
            else 
            {
                flag3 = 0;  // 是回车就跳出判断
            }
        }
        if(flag4 == 1)  // 前面的已经是 /* 
        {
            if(ch1 != '*' && flag5 != 1)   //普通字符跳过
            {
                continue;
            }
            else if( ch1 == '*')  // 第二个* 
            {
                flag5 = 1; //表示遇到了第二个* 
                continue;
            }
            if(flag5 == 1 && ch1 == '/')  // 第二个/ 表明结束
            {
                flag4 = 0;
                flag1 = 0;
                flag3 = 0;
                flag5 = 0;
                continue;
            }
        }
        fputc(ch1,fp2);

    }
    fclose(fp1);
    fclose(fp2);
    return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-07 20:21
签耀等华
双非硬上算法:我咋那么想举办你呢,铁铁
点赞 评论 收藏
分享
斑驳不同:还为啥暴躁 假的不骂你骂谁啊
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务