算法分析实验

实验一、算法分析实验

专业:商业软件工程   姓名:李智濠  学号:201506110117

一、        实验目的

 

编制一个词法分析程序。

二、        实验内容和要求

输入:源程序字符串

输出:二元组(种别,单词本身)

待分析语言的词法规则。

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

 

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

可执行程序名:kenk.exe

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

对字符串表示的源程序

从左到右进行扫描和分解

根据词法规则

识别出一个一个具有独立意义的单词符号

以供语法分析之用

发现词法错误,则返回出错信息

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

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define _KEY_WOED_END "waiting for your expanding" //关键字结束标志

typedef struct
{
int typenum;
char * word;
}WORD;

char input[255];

char token[255]="";

int p_input;

int p_token;

char ch; //当前所读的字符

char *rwtab[]={"begin","if","then","while","do","end",_KEY_WOED_END}; //C语言关键字

WORD * scaner(); //词法扫描函数,获得关键字

main()
{
int over=1;
WORD *oneword;
oneword=(WORD *)malloc(sizeof(WORD));
printf("请输入您的单词(以#作为结束标志):");
scanf("%[^#]s",input); //读入源程序字符串到缓冲区,以#结束,允许多行输入
p_input=0;
printf("您输入的单词是:%s\n\n",input);
while(over<1000&&over!=-1)
{
oneword=scaner();
printf("(%d,%s)",oneword->typenum,oneword->word);
over=oneword->typenum;
}
printf("\n按#可推出程序");
scanf("%[^#]s",input);
}

//需要用到的自编函数参考实现
//从输入缓冲区读取一个字符到ch中

char m_getch(){
ch=input[p_input];
p_input=p_input+1;
return (ch);
}

//去掉空白字符
void getbc()
{
while(ch==‘ ‘||ch==10){
ch=input[p_input];
p_input=p_input+1;
}
}

//拼接单词
void concat()
{
token[p_token]=ch;
p_token=p_token+1;
token[p_token]=‘\0‘;
}

//判断是否字母
int letter()
{
if(ch>=‘a‘&&ch<=‘z‘||ch>=‘A‘&&ch<=‘Z‘)return 1;
else return 0;
}

//判断是否数字
int digit()
{
if(ch>=‘0‘&&ch<=‘9‘)
return 1;
else
return 0;
}

//检索关键字表格
int reserve()
{
int i=0;
for(i=0;i<7;i++)
{
if(!strcmp(rwtab[i],token))
{
return i+1;
}
i=i+1;
}
return 10;
}

//回退一个字符
void retract()
{
p_input=p_input-1;
}

/*数字转换成二进制
char *dtb()
{
return NULL;
}
*/

WORD *scaner()
{
WORD *myword;
myword=(WORD *)malloc(sizeof(WORD));
myword->typenum=10;
myword->word="";
p_token=0;
m_getch();
getbc();
if(letter())
{
while(letter()||digit())
{
concat();
m_getch();

}
retract();
myword->typenum=reserve();
myword->word=token;
return(myword);
}
else if(digit())
{
while(digit())
{
concat();
m_getch();
}
retract();
myword->typenum=20;
myword->word=token;
return(myword);
}
else
{
switch(ch)
{
case ‘=‘:m_getch();
if(ch==‘=‘)
{
myword->typenum=39;
myword->word="==";
return(myword);
}
retract();
myword->typenum=21;
myword->word="=";
return(myword);
break;
case ‘+‘:
myword->typenum=22;
myword->word="+";
return(myword);
break;
case ‘-‘:
myword->typenum=23;
myword->word="-";
return(myword);
break;
case ‘*‘:
myword->typenum=24;
myword->word="*";
return(myword);
break;
case ‘/‘:
myword->typenum=25;
myword->word="/";
return(myword);
break;
case ‘(‘:
myword->typenum=26;
myword->word="(";
return(myword);
break;
case ‘)‘:
myword->typenum=27;
myword->word=")";
return(myword);
break;
case ‘[‘:
myword->typenum=28;
myword->word="[";
return(myword);
break;
case ‘]‘:
myword->typenum=29;
myword->word="]";
return(myword);
break;
case ‘{‘:
myword->typenum=30;
myword->word="{";
return(myword);
break;
case ‘}‘:
myword->typenum=31;
myword->word="}";
return(myword);
break;
case ‘,‘:
myword->typenum=32;
myword->word=",";
return(myword);
break;
case ‘:‘:
myword->typenum=33;
myword->word=":";
return(myword);
break;
case ‘;‘:
myword->typenum=34;
myword->word=";";
return(myword);
break;
case ‘>‘:
myword->typenum=35;
myword->word=">";
return(myword);
break;
case ‘<‘:
myword->typenum=36;
myword->word="<";
return(myword);
break;
case ‘!‘:
m_getch();
if(ch==‘=‘)
{
myword->typenum=40;
myword->word="!=";
return(myword);
}
retract();
myword->typenum=-1;
myword->word="ERROR";
return(myword);
break;
case ‘\0‘:
myword->typenum=1000;
myword->word="OVER";
return(myword);
break;
default:
myword->typenum=-1;
myword->word="ERROR";
return(myword);
}
}
}

  1. 4.      运行结果及分析

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

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

 

 

 

 

四、        实验总结

对要输出的字符串和字符组不是很熟悉,虽然网上有代码参考,但还是不懂。

时间: 2024-10-24 07:51:03

算法分析实验的相关文章

算法分析实验之采花生遗留数组问题的解决

题目描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着一张小小的纸条:“欢迎免费品尝我种的花生!——熊字”. 鲁宾逊先生和多多都很开心,因为花生正是他们的最爱.在告示牌背后,路边真的有一块花生田,花生植株整齐地排列成矩形网格(如图1). 有经验的多多一眼就能看出,每棵花生植株下的花生有多少.为了训练多多的算术,鲁宾逊先生说:“你先找出花生最多的植株,去采摘它的花生:然后再找出剩下的植株里花生最多的,去采摘它的花生:依此类推,不过你一定要在我限定的

最大约数个数算法分析

   最大约数个数算法分析   实验问题描述 正整数x的约数是能整除x的正整数.正整数x的约数个数记为div(x),例如,1,2,5,10都是正整数10的约数,且div(10)=4.设a和b是2个正整数,a<=b,找出a和b当中约数个数最多的数x,输出其约数个数值.   实验目的 本次实验通过利用数论知识,建立素数表,弥补累除法在时间复杂度上的缺陷,同时又结合累除法在小范围内能够计算出最准确的约数个数的特性, 在时间复杂度上获得最大的优化.   实验知识准备过程 累除法的基本思想:计算正整数a的

算法分析与设计——贪心法实验报告

   算法导论  课程设计 成 绩 题    目:    贪心法 学院班级:        1613013         学    号:      16130130216       姓    名:        库 妍           主讲教师:        张立勇          日    期:       2019.5.9         一.Knapsack Problem 1.实验题目 下面有5个具有值和权重列表的项目,背包最多可以包含100磅.解决了分数背包和0/1背包问题

算法分析与设计——分治法实验报告

   算法导论  课程设计 成 绩 题    目:  算法导论课程设计实验报告 学院班级:        1613013         学    号:      16130130216       姓    名:        库 妍           主讲教师:        张立勇          日    期:       2019.6.3         录 分治法 一.Implement exercise 2.3-7................................

算法分析与设计——动态规划法实验报告

   算法导论  课程设计 成 绩 题    目:    动态规划法 学院班级:        1613013         学    号:      16130130216       姓    名:        库 妍           主讲教师:        张立勇          日    期:       2019.4.11         (1)描述最优子结构:如果最优的加括号的方式将其分解为Ai..k与Ak+1..j的乘积,则分别对Ai..k与Ak+1..j加括号的方式也

南邮算法分析与设计实验2 动态规划法

动态规划法 实验目的: 加深对动态规划法的算法原理及实现过程的理解,学习用动态规划法解决实际应用中的最长公共子序列问题. 实验内容: 用动态规划法实现求两序列的最长公共子序列,其比较结果可用于基因比较.文章比较等多个领域. 实验要求: 掌握动态规划法的思想,及动态规划法在实际中的应用:分析最长公共子序列的问题特征,选择算法策略并设计具体算法,编程实现两输入序列的比较,并输出它们的最长公共子序列. 实验原理及内容(包括操作过程.结果分析等) 1.最长公共子序列(LCS)问题是:给定两个字符序列X=

南邮算法分析与设计实验3 回溯法

回溯法 实验目的: 学习编程实现深度优先搜索状态空间树求解实际问题的方法,着重体会求解第一个可行解和求解所有可行解之间的差别.加深理解回溯法通过搜索状态空间树.同时用约束函数剪去不含答案状态子树的算法思想,会用蒙特卡罗方法估计算法实际生成的状态空间树的结点数. 实验内容: 1.求24点问题 给定四个1-9之间的自然数,其中每个数字只能使用一次,用算术运算符+,-,*,/构造出一个表达式,将这4个正整数连接起来(可以使用括号),使最终的得数为24.要求根据问题的特征设计具体算法并编程实现,输入数据

南邮算法分析与设计实验4 密码算法

实验目的 了解现代密码学的基本原理和数论的基础知识,掌握非对称密码体制的著名代表RSA加密算法的工作原理和流程,并设计实现一个简单的密钥系统. 实验内容 了解加/解密的基本原理和工作过程,用公开密钥对明文进行加密,并用私人密钥对密文进行解密,构造一个简单的 RSA 公开密钥系统. 实验原理 1.RSA算法是由麻省理工学院的 Ron Rivest,Adi Shamir 和Len Adleman 于 1977 年研制并于1978 年首次发表的一种算法,是第一个能同时用于加密和数字签名的算法,且易于理

南邮算法分析与设计实验1 分治策略

分治策略 实验目的: 理解分治法的算法思想,阅读实现书上已有的部分程序代码并完善程序,加深对分治法的算法原理及实现过程的理解. 实验内容: 用分治法实现一组无序序列的两路合并排序和快速排序.要求清楚合并排序及快速排序的基本原理,编程实现分别用这两种方法将输入的一组无序序列排序为有序序列后输出. 代码: #include <iostream> #include <cstdlib> #include <ctime> using namespace std; void Swa