# hqqiproject # 数学考试系统 - 项目说明文档 ## 项目概述 这是一个基于C++实现的智能数学题目生成系统,支持小学、初中、高中三个不同难度级别的题目自动生成。系统具有用户管理、题目查重、文件保存和日志记录等完整功能。 ## 项目结构 ### 核心模块 | 模块 | 文件 | 功能描述 | | -------- | ------------------------- | ---------------------------- | | 主程序 | `main.cc` | 程序入口,系统配置和启动 | | 系统核心 | `exam_system.h/.cc` | 系统主流程控制,用户会话管理 | | 题目生成 | `problem_generator.h/.cc` | 不同难度题目生成器实现 | | 文件管理 | `file_manager.h/.cc` | 用户目录和题目文件管理 | | 查重服务 | `duplicate_checker.h` | 题目重复性检查 | | 输入验证 | `input_validator.h/.cc` | 各类输入数据验证 | | 日志系统 | `logger.h/.cc` | 分级日志记录 | ## 详细设计说明 ### 1. 系统架构 ```mermaid graph TD A[ExamSystem
系统控制中心] --> B[ProblemGenerator
题目生成器] A --> C[FileManager
文件管理器] A --> D[DuplicateChecker
查重服务] B --> B1[小学生成器] B --> B2[初中生成器] B --> B3[高中生成器] C --> C1[目录操作] C --> C2[文件操作] D --> D1[历史题目管理] D --> D2[重复检查] ``` ### 架构分层说明 | 层次 | 组件 | 职责 | 设计模式 | | :--------- | :----------------- | :------------ | :----------------- | | 用户交互层 | 用户界面 | 控制台I/O处理 | - | | 核心控制层 | ExamSystem | 系统流程控制 | 状态模式 | | 业务逻辑层 | ProblemGenerator等 | 核心业务处理 | 工厂模式、策略模式 | | 数据访问层 | FileManager | 数据持久化 | - | | 基础设施层 | Logger等 | 支撑服务 | 单例模式 | | 数据存储层 | 文件系统 | 数据存储 | - | ### 2. 用户管理 **预置用户账户**: - 小学组:张三1、张三2、张三3 - 初中组:李四1、李四2、李四3 - 高中组:王五1、王五2、王五3 - 密码:均为"123" ### 3. 题目生成器设计 #### 3.1 小学题目生成器 (`PrimarySchoolGenerator`) - **运算符**:+、-、×、÷ - **特点**:确保计算结果不为负数 - **操作数**:2-5个 - **数值范围**:1-100 **示例题目**:15 + 23 - 7 × 3 #### 3.2 初中题目生成器 (`MiddleSchoolGenerator`) - **新增运算符**:平方(²)、开根号(√) - **特点**:至少包含一个特殊运算符 - **操作数**:1-5个 **示例题目**:(5)² + √16 × 3 #### 3.3 高中题目生成器 (`HighSchoolGenerator`) - **新增运算符**:sin、cos、tan - **特点**:包含三角函数计算 - **角度范围**:0-360度 **示例题目**:sin(45°) + cos(90°) × 2 ### 4. 核心算法实现 #### 4.1 表达式求值算法 ```cpp // 处理运算符优先级:先乘除,后加减 int EvaluateExpression(const std::string& expression) { // 1. 分词处理 // 2. 第一遍:处理乘除法 // 3. 第二遍:处理加减法 // 4. 返回最终结果 } ``` #### 4.2 题目查重机制 - 基于用户名的题目历史记录 - 实时检查新生成题目是否重复 - 支持历史题目加载 #### 4.3 文件命名策略 ```cpp // 格式:YYYY-MM-DD-HH-MM-SS.txt std::string GenerateFilename() { //1.获取当前时间 //2.生成格式字符串 //3.返回文件名 } ``` ### 5. 系统配置参数 | 参数 | 值 | 说明 | | :------------- | :--- | :------------------------- | | 最小题目数量 | 10 | 单次生成最少题目数 | | 最大题目数量 | 30 | 单次生成最多题目数 | | 操作数最小值 | 1 | 题目中数字的最小值 | | 操作数最大值 | 100 | 题目中数字的最大值 | | 最大操作数个数 | 5 | 单个题目最多包含的数字个数 | ### 6. 使用流程 1. **启动系统** ```bash ./exam_system ``` 2. **用户登录** ```bash 请输入用户名和密码(用空格隔开): 张三1 123 ``` 3. **题目生成** ```BASH 当前选择为小学出题 准备生成小学数学题目,请输入生成题目数量(输入-1将退出当前用户,重新登录): 15 ``` 4. **类型切换** ```bash 切换为初中 准备生成初中数学题目,请输入生成题目数量... ``` 5. **退出登录** ```bash 准备生成小学数学题目,请输入生成题目数量(输入-1将退出当前用户,重新登录): -1 ``` ### 7. 文件存储结构 ```text 项目根目录/ ├── 张三1/ │ ├── 2025-01-15-10-30-45.txt │ └── 2025-01-15-11-15-20.txt ├── 李四1/ │ └── 2025-01-15-09-45-10.txt └── 王五1/ └── 2025-01-15-14-20-35.txt ``` ### 8. 设计模式应用 #### 8.1 工厂模式 ```cpp std::unique_ptr factory = ProblemGeneratorFactory::CreateGenerator("小学"); ``` #### 8.2 策略模式 不同难度的题目生成器实现统一的`ProblemGenerator`接口 #### 8.3 单例模式 日志系统和文件管理器使用静态方法提供全局访问 ### 9.系统要求 **操作系统** - **仅支持 Windows 系统** - 不支持 Linux、macOS 等其他操作系统 **编译器要求** - **支持 C++17 标准的编译器** - 推荐使用: - Microsoft Visual Studio 2017 或更高版本 - MinGW-w64 (GCC 8.0 或更高版本) - Clang with MSVC backend ### 10.编译和运行 **先到src目录下** ```bash cd src ``` **编译命令**: ```bash g++ -std=c++17 -Wall -Wextra -I. -Iexam_system -Ifile_manager -Ilogger -o exam_system main/main.cc exam_system/exam_system.cc exam_system/problem_generator.cc exam_system/duplicate_checker.cc exam_system/input_validator.cc file_manager/file_manager.cc logger/logger.cc ``` **或者** ```bash cd ../build --config Debug --target all -j 12 -- ``` **运行**: ```bash .\exam_system.exe ``` ## 核心类介绍请看doc\ExamSystem.md