Free考研资料 - 免费考研论坛

 找回密码
 注册

编译原理,词法分析程序!有的请进来!

[复制链接]
orangebaby 发表于 06-3-18 23:46:02 | 显示全部楼层 |阅读模式
网上很多词法分析程序的源代码都是错误一堆的,根本没法用,还有很多是骗人的!我急需阿!拜托了!
sorcererwdj 发表于 06-3-19 11:20:31 | 显示全部楼层
yun
 楼主| orangebaby 发表于 06-3-23 21:16:54 | 显示全部楼层
#include<stdio.h>
#include<malloc.h>
#include<string.h>
#define NULL 0
#define LEN sizeof(struct project)

struct project /*存放代码的结构体*/
{char c;
struct project *next;
};

struct keyword  /*存放保留字表*/
{char key[10];
char vc[7];
}stu[13]={{\"program\",\"(3,0)\"},{\"var\",\"(4,0)\"},{\"procedure\",\"(5,0)\"},{\"begin\",\"(6,0)\"},
{\"end\",\"(7,0)\"},{\"if\",\"(8,0)\"},{\"then\",\"(9,0)\"},{\"else\",\"(10,0)\"},{\"while\",\"(11,0)\"},
{\"do\",\"(12,0)\"},{\"call\",\"(13,0)\"},{\"integer\",\"(14,0)\"},{\"real\",\"(15,0)\"}};

int n;
int j=1;/*记录标志符的个数*/
char TOKEN[20];
char DATA[10];

struct project * creat(void)/*初始化代码结构体*/
{struct project *head;
struct project *p1,*p2;
n=0;
p1=p2=(struct project *)malloc(LEN);
scanf(\"%c\",&p1->c);
head=NULL;
while(p2->c!=\'#\')
{n=n+1;
  if(n==1) head=p1;
  else p2->next=p1;
  p2=p1;
  p1=(struct project *)malloc(LEN);
  scanf(\"%c\",&p1->c);
}
p2->next=NULL;
return(head);
}

void print(struct project *head)
{struct project *p0;
p0=head;
if(head!=NULL)
         do
         {printf(\"%c\",p0->c);
          p0=p0->next;
         }while(p0!=NULL);
}



void lookup(void)/*查保留字表*/
{
        int m=0;
       
        while(m<13)
        {
                if(strcmp(stu[m].key,TOKEN)!=0) m++;
                if(strcmp(stu[m].key,TOKEN)==0) {printf(\"%s:%s\\t\",stu[m].key,stu[m].vc);break;}
        }

                if(m>=13) printf(\"%s:(1,%d)\\t\",TOKEN,j++);
}

void main()
{
        struct project *head,*p,*p1;
        int i,d,r;
       
        printf(\"input the project:\\n\");
    p=head=creat();


        while(p->c!=\'#\'){
                if(p->c==\' \') p=p->next;
                if(p->c==\'\\n\') p=p->next;

            if(p->c>=\'0\'&&p->c<=\'9\')
                {
                        DATA[0]=p->c;
                        p=p->next;d=1;

                        while(p->c>=\'0\'&&p->c<=\'9\')
                        {
                                DATA[d]=p->c;d++;
                                p=p->next;
                        }
                        if((p->c>=\'a\'&&p->c<=\'z\')||(p->c>=\'A\'&&p->c<=\'Z\'))
                                printf(\"**error**\");
                        else
                        {
                                printf(\"(2,\");
                                for(r=0;r<d;r++)
                                        printf(\"%c\",DATA[r]);
                                printf(\")\\t\");
                        }
                }

                       

                if((p->c>=\'a\'&&p->c<=\'z\')||(p->c>=\'A\'&&p->c<=\'Z\'))
                {
                        TOKEN[0]=p->c;
                        p=p->next;i=1;

                        while((p->c>=\'a\'&&p->c<=\'z\')||(p->c>=\'A\'&&p->c<=\'Z\')||(p->c>=\'0\'&&p->c<=\'9\'))
                        {
                                TOKEN=p->c;i++;
                                p=p->next;
                        }

                        TOKEN=\'\\0\';
                        lookup();
                       
                }
        else
                switch(p->c)
                {
                        case\'<\':p=p->next;
                                if(p->c==\'=\') {printf(\"<=:(24,0)\\t\");p=p->next;}
                                else if(p->c==\'>\') {printf(\"<>:(28,0)\\t\");p=p->next;}
                                else printf(\"<:(23,0)\\t\");
                                break;
                               
                        case\'=\':printf(\"=:(27,0)\\t\");p=p->next;break;
                        case\'>\':p=p->next;
                                if(p->c==\'=\') {printf(\">=:(26,0)\\t\");p=p->next;}
                                else printf(\">:(25,0)\\t\");break;
                        case\'+\':printf(\"+:(16,0)\\t\");p=p->next;break;
                        case\'-\':printf(\"-:(17,0)\\t\");p=p->next;break;
                        case\'*\':printf(\"*:(18,0)\\t\");p=p->next;break;
                        case\'/\':p=p->next;
                                if(p->c==\'*\')
                                {
                                        do{p1=p;p=p1->next;}while(p1->c==\'*\'&&p->c==\'/\');
                                        printf(\"/*注释*/\\t\");
                                        p=p->next;
                                }
                else printf(\"/:(19,0)\\t\");p=p->next;break;
                        case\'~\':printf(\"~:(20,0)\\t\");p=p->next;break;
                        case\':\':printf(\"::(21,0)\\t\");p=p->next;break;
                        case\';\':printf(\";:(30,0)\\t\");p=p->next;break;
                        case\'.\':printf(\".:(31,0)\\t\");p=p->next;break;
                        case\',\':printf(\",:(32,0)\\t\");p=p->next;break;
                        case\'(\':printf(\"(:(33,0)\\t\");p=p->next;break;
                        case\')\':printf(\"):(34,0)\\t\");p=p->next;break;
                }
       
        }
       
}
 楼主| orangebaby 发表于 06-3-23 21:18:18 | 显示全部楼层
绝对可以运行的
哈哈
靠自己也可以嘛
编译原理!!!
venulboy 发表于 06-3-24 13:47:50 | 显示全部楼层
谢谢orangebaby,
楼主,我沾你的光把这段代码拿走拉,,,,
呵呵,谢谢拉
solcmon 发表于 06-3-30 09:32:58 | 显示全部楼层
真是雪中送碳啊!太谢谢了!
chenweihua2005 发表于 06-4-3 16:53:40 | 显示全部楼层
ding le  xian
yzg1972 发表于 06-4-13 05:45:23 | 显示全部楼层

ding

ding
jxxb 发表于 06-5-25 20:32:46 | 显示全部楼层
非常感谢
谢谢啊
欢迎来到免费考研网www.freekaoyan.com
5624521 发表于 06-5-26 12:37:05 | 显示全部楼层
ding ding
您需要登录后才可以回帖 登录 | 注册

本版积分规则

联系我们|Free考研资料 ( 苏ICP备05011575号 )

GMT+8, 25-1-21 07:13 , Processed in 0.093009 second(s), 10 queries , Gzip On, Xcache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表