用C语言实现以上问题

时间: 2024-02-18 21:02:23 浏览: 21
以下是用C语言实现以上问题的代码: ```c #include <stdio.h> #include <string.h> #define MAX_PACKAGE_NUM 1000 //最大包裹数 #define MAX_NAME_LEN 20 //最大姓名长度 #define MAX_PHONE_LEN 15 //最大电话长度 #define MAX_ADDR_LEN 50 //最大地址长度 #define MAX_ORDER_LEN 20 //最大单号长度 //包裹信息结构体 typedef struct package { char id[MAX_ORDER_LEN]; //单号 char name[MAX_NAME_LEN]; //姓名 char phone[MAX_PHONE_LEN]; //电话 char address[MAX_ADDR_LEN]; //地址 } Package; //包裹信息表格 Package package_table[MAX_PACKAGE_NUM]; int package_num = 0; //包裹数量 //添加包裹 void add_package() { if (package_num >= MAX_PACKAGE_NUM) { printf("已达到最大包裹数,无法添加新的包裹\n"); return; } Package new_package; printf("请输入包裹信息:\n"); printf("单号:"); scanf("%s", new_package.id); printf("姓名:"); scanf("%s", new_package.name); printf("电话:"); scanf("%s", new_package.phone); printf("地址:"); scanf("%s", new_package.address); package_table[package_num++] = new_package; printf("成功添加一条包裹信息\n"); } //比较两个包裹的地址大小 int compare_address(Package p1, Package p2) { return strcmp(p1.address, p2.address); } //比较两个包裹的单号大小 int compare_id(Package p1, Package p2) { return strcmp(p1.id, p2.id); } //包裹排序 void sort_packages() { //按地址排序 for (int i = 0; i < package_num; i++) { for (int j = i + 1; j < package_num; j++) { if (compare_address(package_table[i], package_table[j]) > 0) { Package temp = package_table[i]; package_table[i] = package_table[j]; package_table[j] = temp; } } } //按单号排序 for (int i = 0; i < package_num; i++) { for (int j = i + 1; j < package_num; j++) { if (compare_address(package_table[i], package_table[j]) == 0 && compare_id(package_table[i], package_table[j]) > 0) { Package temp = package_table[i]; package_table[i] = package_table[j]; package_table[j] = temp; } } } printf("成功排序所有包裹\n"); } //查找包裹编号 void find_package() { char name[MAX_NAME_LEN]; char phone[MAX_PHONE_LEN]; char id[MAX_ORDER_LEN]; printf("请输入要查找的包裹信息:\n"); printf("姓名:"); scanf("%s", name); printf("电话:"); scanf("%s", phone); printf("单号:"); scanf("%s", id); int found = 0; for (int i = 0; i < package_num; i++) { if (strcmp(package_table[i].name, name) == 0 && strcmp(package_table[i].phone, phone) == 0 && strcmp(package_table[i].id, id) == 0) { printf("包裹编号为:%d\n", i); found = 1; break; } } if (!found) { printf("没有找到对应的包裹信息\n"); } } //主函数 int main() { int choice; while (1) { printf("请输入操作编号:\n"); printf("1. 添加包裹\n"); printf("2. 排序包裹\n"); printf("3. 查找包裹编号\n"); printf("4. 退出程序\n"); scanf("%d", &choice); switch (choice) { case 1: add_package(); break; case 2: sort_packages(); break; case 3: find_package(); break; case 4: return 0; default: printf("无效的操作编号,请重新输入\n"); } } return 0; } ``` 在上面的代码中,我们使用了一个结构体来表示包裹信息,包括单号、姓名、电话和地址。我们使用一个静态数组来表示包裹信息表格,使用一个变量记录当前包裹数量。实现了添加包裹、排序包裹和查找包裹编号等功能。

相关推荐

最新推荐

recommend-type

使用C语言实现CRC校验的方法

本篇文章是对使用C语言实现CRC校验的方法进行了详细的分析介绍,需要的朋友参考下
recommend-type

C语言实现的排列组合问题的通用算法、解决方法

主要介绍了C语言实现的排列组合问题的通用算法、解决方法,本文使用C语言实现在程序中解决这个问题,需要的朋友可以参考下
recommend-type

CRC4的C语言实现代码

这里给大家分享一个函数,实现DSP通讯中的CRC4校验 。特征码为0x13。
recommend-type

C语言接口与实现方法实例详解

主要介绍了C语言接口与实现方法,包括接口的概念、实现方法及抽象数据类型等,并配合实例予以说明,需要的朋友可以参考下
recommend-type

C语言实现餐饮结账管理系统

主要为大家详细介绍了C语言实现餐饮结账管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节 线性代数的核心问题是求解方程组。这些方程都是线性的,即未知数仅与数相乘——我们绝不会 遇见 x 乘以 y。我们的第一个线性方程组较小。接下来你来看看它引申出多远: 两个方程 两个未知数 x − 2y = 1 3x + 2y = 11 (1) 我们一次从一个行开始。第一个方程 x − 2y = 1 得出了 xy 平面的一条直线。由于点 x = 1, y = 0 解 出该方程,因此它在这条直线上。因为 3 − 2 = 1,所以点 x = 3, y = 1 也在这条直线上。若我们选择 x = 101,那我们求出 y = 50。 这条特定直线的斜率是 12,是因为当 x 变化 2 时 y 增加 1。斜率在微积分中很重要,然而这是线 性代数! 图 2.1 将展示第一条直线 x − 2y = 1。此“行图”中的第二条直线来自第二个方程 3x + 2y = 11。你 不能错过两条线的交点 x = 3, y = 1。点 (3, 1) 位于两条线上并且解出两个方程。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

识别MATLAB微分方程求解中的混沌行为:分析非线性方程混沌行为的实用技巧

![matlab求解微分方程](https://img-blog.csdnimg.cn/2021062810300367.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MTQ3OTY3OA==,size_16,color_FFFFFF,t_70) # 1. MATLAB微分方程求解概述 微分方程是描述物理、工程和金融等领域中动态系统的数学模型。MATLAB提供了强大的工具来求解微分方程,包括内置求解器和自定义函数
recommend-type

physon如何做ERP系统

作为一个AI语言模型,我可以给您提供一些基本的建议和思路: 1.明确需求和目标:在开始开发ERP系统之前,需要明确您的业务需求和目标,了解您的业务流程、流程数据、员工角色和权限、财务管理等方面的要求,这样才能更好的设计和开发ERP系统。 2.选择技术框架和开发工具:选择合适的技术框架和开发工具是ERP系统开发的关键。选择一种流行的技术框架和工具可以提高开发效率和质量。 3.设计数据库:ERP系统需要一个功能强大的数据库来存储数据。设计数据库需要考虑数据的完整性、安全性和可扩展性。 4.设计系统架构:系统架构是ERP系统的骨架,需要考虑系统的可扩展性、可维护性和性能。 5.开发和测试:
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。