Skip to content

ChengxiX/Bookstore-2024

 
 

Repository files navigation

书店管理系统

SJTU ACM 班 2024 级程序设计课程大作业

目录

简介

实现一个用 C++ 语言编写的书店管理系统,用于向店家和顾客提供图书检索与购买相关服务。

本项目目标如下:

  • 培养学生工程开发的能力(全套的开发过程与程序的封装等);
  • 培养学生编写文档的能力(需求文档/设计文档的编写);
  • 培养学生的代码管理能力(git 的使用),拥有良好的代码规范意识;
  • 提升学生的编程学习与实践能力(块状链表的学习实现);
  • 培养学生对编写软件的兴趣(见 bonus)。

关于本仓库

关于本仓库有任何问题欢迎联系助教,也可以直接 pull request;本仓库内容将维护至本作业结束,请保持关注题面更改,助教也会及时发布相关通知。

作业说明

评测方式

公开的评测数据可以从 SJTU jBox 下载。

注意,每个 testcase 为最小评测数据单元;在测试同一 testcase 的多个输入(.in)过程中,对于每个输入,都会运行学生程序,完成后关闭程序,再以下一个输入运行学生程序,但过程中不会清除学生程序运行生成的数据文件。而每个 testcase 测试结束后会清除所有学生程序生成的文件,再运行下一个 testcase。

Online Judge(以下简称 OJ)提交方式为提交 git repo 链接,提交内容应为形如 https://github.com/username/repo 的链接。编译评测方式详见 OJ 首页说明。OJ 使用沙盒评测文件读写。编译生成的可执行文件名应为 code,否则 OJ 无法运行。

由于网络原因可能会导致评测机 clone 仓库失败。

本地评测可用脚本评测,评测脚本已包含于数据包中,在含有 ./code 的目录下运行脚本即可。例如你的 code./cmake-build-debug,数据在 ./data,则运行 cd cmake-build-debug; ../data/judge 即可。如运行评测脚本出现问题,请联系助教。

评测数据量(帐户和图书数量)不会超过 $1\times10^5$ 数量级。

分数组成

本作业满分为 100%,最终将以本作业占本课程成绩总分分数折算入课程成绩。

得分项 分值 说明
正确性 55% 通过所有公开数据点
鲁棒性 10% 通过所有非公开数据点
文档编写 15% 助教评分
Code Review 20% Git 仓库管理、代码规范等
Bonus 最高 10% 具体各项得分见 bonus
总计 110% 未通过正确性测试者 bonus 不能得分

时间表

助教将在固定时间节点检查学生的完成进度。如遇困难请提前联系助教。

  • Week 0 (对应校历 2024-2025 学年第一学期第 12 周)

    • 周四(12 月 5 日):发布项目和 业务要求文档,开始完成需求分析文档
  • Week 1 (对应校历 2024-2025学年第一学期第 13 周)

    • 周一(12 月 9 日):检查需求分析文档(分数占比 5pt);发布标准要求文档
  • Week 2

    • 周四(12 月 19 日 18:30 前):通过前置作业评测;
    • 周五(12 月 20 日):中期检查,检查总体设计文档编写情况以及主体部分构思(分数占比 5pt);
  • Week 4 (对应校历第 16 周)

    • 周四(1 月 2 日 18:30 前):通过测试点评测;
      • 非公开测试点和 Bonus 部分截止日期同主体逻辑,超时完成的部分不计分;
    • 周五(1 月 3 日晚):进行代码检查(Code Review);

友情提醒:临近期末,请尽早开工。

项目说明

开发要求

每位学生均需完成一份需求分析文档、总体设计文档。文档 请使用 Markdown 书写。

需求分析文档

根据给出的要求文档,你需要用图或文字描述书店系统各个子系统的业务流程和数据流图。文档具体要求如下:

  • 业务流图

    • 请绘制书店系统的业务流图;
  • 数据流图

    • 请绘制书店系统的数据流图;
  • 数据词典

    • 请描述书店系统涉及的数据项及其含义;
  • 功能说明

    • 请描述书店系统各个模块的功能,包括模块名称、功能描述、输入输出参数。例如:

        1. 功能1:名字、输入、输出、所做的处理
        1. 功能2
        1. ...
  • 用户交互设计

    • 请设计所有的命令格式和对应的输出;

总体设计文档

你的总体设计文档应当包括如下部分:

  • 项目名称 / 文档作者

  • 程序功能概述

  • 主体逻辑说明

  • 代码文件结构,即 main 函数与各个类的关系

  • 功能设计

    • 请概述各模块的功能和功能结构图;
  • 数据库设计

    • 请指出你需要存储的数据以及存储方式;
  • 类、结构体设计

  • 其他补充说明

如果最后提交代码不符合总体设计文档则会酌情扣分。合理的文档修订是允许的,但请写明修订记录。

Git 版本管理

你需要了解版本库、工作区、暂存区等 git 基础概念,并掌握 git 的常用指令。

你需要合理使用 commit 功能维护代码版本。具体来说:

  • Commit 频率不可以太低(例如,不可以整个项目只有三四个 commit);
    • 频繁的 commit 有助于细致地保存代码变更的历史。
  • Commit message 内容可以清晰简要但不能缺失、不能是无意义内容。
    • 对于比较大的 commit,鼓励用多行的 commit message 具体描述干了什么;
    • 合理的 message 示例:
      • docs: clarify design reasoning and details
      • partial implementation of unrolled linked list
      • fix: 切换帐户之前检查权限
    • 不合理的 message 示例:
      • update
      • Add files via upload
      • Update README.md
      • bugfix (具体修了什么?)
      • 20231122 (git 会自动存储 commit 时间,不用在 commit message 里说明。)

你的 git 仓库需要整体文件结构清晰,了解并自主设置 .gitignore 等文件,保证编译产物(./codecmake-build-debug 等)和下发的测试数据点不进入 git 仓库。Git repository 总大小(包括 .git 文件夹在内的 worktree)不得超过 5 MiB。

违反者会在 code review 中被扣分。

代码风格

选择合适的代码风格,严格遵守选定风格的代码规范。

Bonus

bonus 文档

扣分

请保证自己项目结构的可读性,可以包括优化项目结构、适当的文件树指南等,晦涩难懂的项目可能会加大助教的工作量,也可能会影响你的成绩。

如有出现任何抄袭现象按 0 分计。

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 98.7%
  • Other 1.3%