一、设计要求
该程序旨在实现一个火车车次排序系统,以便用户可以根据其需求选择不同的排序规则来排序火车车次信息。为了满足这一目标,需要定义适当的数据结构,包括火车车次信息、出发时间和到达时间等字段。在程序中,使用了一个名为Train的结构体来表示每个火车车次,包括火车车次号、出发时间和到达时间。这个数据结构的定义是程序的基础,它允许有效地存储和处理火车信息。
排序功能是该系统的核心功能之一。用户可以选择按照出发时间升序排序或按照到达时间降序排序。为了实现排序,在程序中使用了两个比较函数compareByDeparture和compareByArrival,它们分别用于按出发时间升序和按到达时间降序排序。这些比较函数是通过标准库函数qsort来调用的,它们确保了排序的正确性和效率。
用户交互是该系统的另一个关键方面。通过一个用户界面来实现用户选择排序规则的功能。用户可以从菜单中选择排序选项,包括按照出发时间升序排序、按照到达时间降序排序以及退出程序选项。通过使用循环,程序会根据用户的选择执行相应的排序操作,并将排序结果输出给用户。
👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈
二、设计思路
在本节中,将详细描述如何实现概要设计中定义的所有数据类型、操作接口,以及主程序和其他模块的函数实现,同时为了更清晰地表示模块之间的调用关系,将绘制一个函数的调用关系图。
数据类型定义:
首先,需要定义抽象数据类型Train,它用于表示火车车次的信息。在C语言中,可以通过结构体来定义Train类型,包括trainNumber、departureTime和arrivalTime字段。
typedef struct { char trainNumber[10]; char departureTime[6]; char arrivalTime[6]; } Train;
操作接口定义:
接下来,需要定义操作接口,这些接口将在各个模块中使用。主要的操作接口包括排序函数和打印函数。
👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈
// 排序函数,根据用户选择的排序规则对火车车次进行排序 void sortTrains(Train trains[], int n, int sortType); // 打印函数,将排序后的火车车次信息输出到屏幕上 void printTrains(Train trains[], int n);
👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈
下面是各模块函数之间的调用关系图:
Main模块 --> Sort模块 --> compareByDeparture 或 compareByArrival --> qsort
Main模块 --> Print模块 --> printTrains
通过上述详细设计,实现了一个完整的火车车次排序系统,包括数据类型的定义、操作接口的定义和各模块的函数实现。模块之间的调用关系图帮助清晰地理解各函数之间的交互,使整个系统更具可读性和可维护性。这个系统能够满足用户的需求,根据不同的排序规则对火车车次信息进行排序,并将排序结果以友好的方式呈现给用户。
三、测试结果
这些测试案例演示了不同的排序规则(出发时间升序和到达时间降序)以及无效选择的情况。每个测试案例的期望结果都与排序规则相匹配,并验证了程序在各种情况下的正确性和鲁棒性。这些测试结果有助于确保程序在不同条件下都能正常工作。注意,上述示例表格中的测试数据是针对代码逻辑的简化示例,实际测试需要更多的数据和情景来覆盖更多的可能性。
👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈
👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈
👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈
四、代码展示
#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct { char trainNumber[10]; char departureTime[6]; char arrivalTime[6]; } Train; int compareByDeparture(const void* a, const void* b) { // 代码 略.... // 代码 略....> 👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈 // 代码 略....> 👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈 } int compareByArrival(const void* a, const void* b) { // 代码 略.... // 代码 略.... // 代码 略.... } void sortTrains(Train trains[], int n, int sortType) { // 代码 略.... // 代码 略.... } // 代码 略.... // 代码 略.... // 代码 略.... // 代码 略.... void printTrains(Train trains[], int n) { for (int i = 0; i < n; i++) { printf("Train Number: %s, Departure: %s, Arrival: %s\n", trains[i].trainNumber, trains[i].departureTime, trains[i].arrivalTime); } } int main() { Train trains[] = { // 代码 略.... // 代码 略.... // 代码 略.... }; int n = sizeof(trains) / sizeof(trains[0]); int choice; while (1) { // 代码 略.... // 代码 略.... switch (choice) { case 1: // 代码 略.... // 代码 略.... break; case 2: // 代码 略.... break; case 3: printf("Exiting program.\n"); return 0; default: printf("Invalid choice. Please try again.\n"); } } return 0; }
👉👉👉 源码获取 关注【测试开发自动化】公众号,回复 “火车” 获取。👈👈👈