C语言程序题自动评分系统的研究与实现
摘要 | 第5-6页 |
ABSTRACT | 第6页 |
第一章 绪论 | 第9-15页 |
1.1 课题的研究背景和意义 | 第9-10页 |
1.1.1 课题的研究背景 | 第9-10页 |
1.1.2 课题的研究意义 | 第10页 |
1.2 国内外研究现状 | 第10-13页 |
1.3 主要研究内容 | 第13-14页 |
1.4 论文的组织结构 | 第14-15页 |
第二章 相关的理论基础 | 第15-23页 |
2.1 C 语言的主要特点 | 第15-16页 |
2.2 编译原理的基础知识 | 第16-18页 |
2.2.1 词法分析 | 第17-18页 |
2.2.2 语法分析 | 第18页 |
2.3 程序题评分的主要方法 | 第18-20页 |
2.3.1 程序动态测试 | 第19页 |
2.3.2 代码静态分析 | 第19-20页 |
2.3.3 动态和静态测试的异同点 | 第20页 |
2.4 字符串匹配和相似度算法 | 第20-23页 |
2.4.1 蛮力匹配算法/BF 算法 | 第21页 |
2.4.2 KMP 算法 | 第21-22页 |
2.4.3 BM 算法 | 第22页 |
2.4.4 编辑距离算法 | 第22-23页 |
第三章 基于动态测试和静态测试相结合的评分方案 | 第23-35页 |
3.1 常见的自动题评分方案和模型 | 第23页 |
3.2 动态和静态相结合的评分方案的可行性 | 第23-25页 |
3.3 动态测试 | 第25-27页 |
3.3.1 程序题目设置 | 第26页 |
3.3.2 运行程序 | 第26-27页 |
3.3.3 结果对比 | 第27页 |
3.4 代码静态检查 | 第27-33页 |
3.4.1 软件质量度量方法 | 第28-29页 |
3.4.2 源程序分析比较方法 | 第29-33页 |
3.4.2.1 选择结构标准化 | 第30-33页 |
3.4.2.2 循环结构标准化 | 第33页 |
3.4.2.3 基于权重的字符串匹配算法 | 第33页 |
3.5 本章小结 | 第33-35页 |
第四章 系统的设计、实现与结果分析 | 第35-49页 |
4.1 系统设计 | 第35-38页 |
4.1.1 系统的功能模块设计 | 第35-36页 |
4.1.2 数据库设计 | 第36-38页 |
4.2 系统实现 | 第38-42页 |
4.2.1 用户登录模块的实现 | 第38-39页 |
4.2.2 试题设计维护和答案设置模块的实现 | 第39-40页 |
4.2.3 编程题答题模块的实现 | 第40-41页 |
4.2.4 编程题评分模块的实现 | 第41-42页 |
4.3 实验及结果分析 | 第42-49页 |
4.3.1 基于关键字对比技术的实验对比 | 第43-46页 |
4.3.2 基于程序结构的代码检查结果对比 | 第46-47页 |
4.3.3 结果分析 | 第47-49页 |
第五章 总结与展望 | 第49-51页 |
5.1 总结 | 第49-50页 |
5.2 展望 | 第50-51页 |
参考文献 | 第51-55页 |
致谢 | 第55页 |