算术表达式语法检查实验报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
中南民族大学计算机科学学院本科课程设计
任务书
设计名称:算术表达式语法检查
指导教师:下达时间: 2015-5-8
学生姓名:学号:
专业:
一、课程设计的基本要求
根据所学知识,编写指定题目的C++语言程序,并规范地完成课程设计报告。通过课程设计,加深对《C++面向对象程序设计》课程所学知识的理解,熟练掌握和巩固C++语言的基本知识和语法规范,掌握C++语言的基础知识,理解面向对象系统的封装性、继承性和多态性;熟练使用C语言中的函数、数组、指针、链表和字符串等基本知识;掌握类的定义、标准String类和向量;理解掌握友元函数和重载操作符,动态数组;理解掌握继承和多态性;掌握模版的使用;能够进行程序调试过程中的异常处理;进一步掌握利用C++进行类的定义和操作方法;进一步掌握类的继承和派生方法;进一步理解虚函数和多态;综合利用上述知识,学习设计并编写面向对象的C++简单应用程序;培养解决复杂任务功能分解方法(自顶向下逐步求精、模块化设计、信息隐藏等)。
学会编制结构清晰、风格良好、数据结构适当的C++语言程序,从而具备利用计算机编程分析解决综合性实际问题的初步能力。
具体要求如下:
1、采取模块化方式进行程序设计,要求程序的功能设计、数据结构设计及整体结构设计合理。学生也可根据自己对题目的理解增加新的功能模块(视情况可另外加分)。
2、系统以菜单界面方式(至少采用文本菜单界面,如能采用图形菜单界面更好)工作,运行界面友好,演示程序以用户和计算机的对话方式进行。
3、程序算法说明清晰,理论分析与计算正确,运行情况良好,实验测试数据无误,容错性强(能对错误输入进行判断控制)。
4、编程风格良好(包括缩进、空行、适当注释、变量名和函数名见名知意,程序容易阅读等);
5、写出规范的课程设计报告,具体要求见相关说明文档。
二、课程设计的主要内容
【问题描述】
算术表达式语法检查。
【功能要求】
(1)键盘读入一个四则运算算术表达式,对其进行语法检查;
(2)算术表达式允许嵌套,如果出错,指出出错位置;
(3)不需要计算结果;
(4)尽量不使用栈。
程序:(其余的你们自己写)
void main() //主函数
{
int len;
int f=1;
cout< gets(str); len = strlen(str); str[len] = '^'; cout< system("pause"); cout< cout<<"***********************词法分析开始*****************"< f = cifa_main(); if ( f == 0 ) return; cout< system("pause"); cout< cout<<"***********************语法分析开始*****************"< f = yufa_main(); if (f== 0) return; cout< system("pause"); cout< } int F1() //F -> (E) | 标识符| 无符号整数{ if ((strcmp(cifa_p->word,"(") == 0 ) ) { advance(); strcpy(F_name,cifa_p->word); strcpy(E_name,F_name); E1(); if ((strcmp(cifa_p->word,")") == 0 ) ) { advance(); strcpy(F_name,E_name); return (1); } else { cout<<"ERROR"< return (0); } } else if ( cifa_p->type == 1 || cifa_p->type == 2) { strcpy(F_name,cifa_p->word); advance(); return (1); } else return 0; } int T1() //T -> F*T | F/T | F { yuyi *p = new yuyi; F1(); strcpy(p->op1,F_name); if (strcmp(cifa_p->word,"*") == 0) { advance(); T1(); p->next =NULL; p->op = '*'; strcpy(p->op2,T_name); T_name[0] = 't'; T_name[1] = ++count; T_name[2] = '\0'; strcpy(p->result,T_name); yuyi_add(p); return(1); } else if (strcmp(cifa_p->word,"/") == 0) { advance(); T1(); p->next =NULL; p->op = '/'; strcpy(p->op2,T_name); T_name[0] = 't';