码迷,mamicode.com
首页 > 其他好文 > 详细

实验一

时间:2016-10-14 20:17:11      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:

 

 

实验一、××实验

专业   姓名  学号

一、        实验目的

设计,编制并调试一个词法分析程序,加深对词法分析原理的理解。

 

二、        实验内容和要求

     设计,编制并调试一个词法分析程序

 

三、        实验方法、步骤及结果测试

 

  1. 1.      源程序名:压缩包文件(rarzip)中源程序名×××.c

可执行程序名:×××.exe

  1. 2.      原理分析及流程图

主要总体设计问题。

(包括存储结构,主要算法,关键函数的实现等)

  1. 3.      主要程序段及其解释:

实现主要功能的程序段,重要的是程序的注释解释。

  1. 4.      运行结果及分析

一般必须配运行结果截图,结果是否符合预期及其分析。

   (截图需根据实际,截取有代表性的测试例子)

2.技术分享 

3.

#include<stdio.h> /*定义I/O库所用的某些宏和变量*/
#include<string.h> /*定义字符串库函数*/
#include<conio.h> /*提供有关屏幕窗口操作函数*/
#include<ctype.h> /*分类函数*/
char prog[80]={\0},
token[8]; /*存放构成单词符号的字符串*/
char ch;
int syn, /*存放单词字符的种别码*/
n,
sum, /*存放整数型单词*/
m,p; /*p是缓冲区prog的指针,m是token的指针*/
char *rwtab[6]={"begin","if","then","while","do","end"};
void scaner()
{
m=0;
sum=0;
for(n=0;n<8;n++)
token[n]=\0;
ch=prog[p++];
while(ch== )
ch=prog[p++];
if(isalpha(ch)) /*ch为字母字符*/
{
while(isalpha(ch)||isdigit(ch)) /*ch 为字母字符或者数字字符*/
{
token[m++]=ch;
ch=prog[p++];}
token[m++]=\0;
ch=prog[p--];
syn=10;
for(n=0;n<6;n++)
if(strcmp(token,rwtab[n])==0) /*字符串的比较*/
{
syn=n+1;
break;}}
else
if(isdigit(ch)) /*ch是数字字符*/
{
while(isdigit(ch)) /*ch是数字字符*/
{
sum=sum*10+ch-0;
ch=prog[p++];}
ch=prog[p--];
syn=11;
}
else
switch(ch)
{
case<:m=0;token[m++]=ch;ch=prog[p++];
if(ch==>){
syn=21;
token[m++]=ch;}
else if(ch===){
syn=22;
token[m++]=ch;}
else{
syn=20;
ch=prog[p--];}
break;
case>:m=0;token[m++]=ch;ch=prog[p++];
if(ch===){
syn=24;
token[m++]=ch;}
else{
syn=23;
ch=prog[p--];}
break;
case::m=0;token[m++]=ch;ch=prog[p++];
if(ch===){
syn=18;
token[m++]=ch;}
else{
syn=17;
ch=prog[p--];}
break;
case+:syn=13;token[0]=ch;break;
case-:syn=14;token[0]=ch;break;
case*:syn=15;token[0]=ch;break;
case/:syn=16;token[0]=ch;break;
case=:syn=25;token[0]=ch;break;
case;:syn=26;token[0]=ch;break;
case(:syn=27;token[0]=ch;break;
case):syn=28;token[0]=ch;break;
case#:syn=0; token[0]=ch;break;
default:syn=-1;}}
main()
{

p=0;
printf("please input string:\n");
do {
ch=getchar();
prog[p++]=ch;
}while(ch!=#);

p=0;
do{
scaner();
switch(syn){
case 11: printf("(%d,%d)\n",syn,sum);break;
// case -1: printf("\n ERROR;\n");break;
default: printf("(%d,%s)\n",syn,token);
}
}while(syn!=0);
//getch();
}

 

4.技术分享

 5.总结

对这个程序真的是不知道要怎么完成,代码是请教同学然后根据自行理解加注释的。

 

实验一

标签:

原文地址:http://www.cnblogs.com/piglet00/p/5961435.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!