数据结构练手小项目(AVL树、哈希表、循环链表、MySQL数据库)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

在这里插入图片描述
@[toc]

前言

本月主打数据结构,当然,月初的时候入门了MySQL。
不过吧,一直学一直学,人都学傻了,死读书读死书,==以练代学,学以致用==才是正道。
这不,我找到了一个数据结构的练手小项目,拿来练练,如果有兴趣,可以一起试试啊。

正文(无删减)

1.主题区域“移动运营商的客户服务”的信息系统应在以下位置输入,存储,处理和显示数据:
-顾客
-移动运营商拥有的SIM卡;
-客户发行或退回SIM卡。

2.有关每个客户端的数据应包含:
护照号码-格式为“ NNNN-NNNNNN”的字符串,其中N为数字;
护照的签发地点和日期-字符串;
名称-字符串;
出生年份-整个;
地址是一个字符串;

注意-线的长度(护照号码除外)由学生独立确定。

3.==客户数据应组织为AVL搜索树==,并==按“护照号”排序==。

4.每个SIM卡的数据必须包含:
SIM卡号码-格式为“ NNN-NNNNNNN”的字符串,其中N是数字
资费是一个字符串
发布年份-整体;
可用性的标志是合乎逻辑的。

注意-线路的长度(“ SIM卡号”除外)由学生独立确定。

5.==SIM卡上的数据应以哈希表的形式进行组织==,==哈希表的主键为“ SIM卡号”==,哈希方法由作业选项确定。
6.客户发行或退回SIM卡的数据必须包含
护照号码-一行,其格式对应于客户数据中的相似行;
SIM卡号-格式对应于SIM卡中数据中类似行的行;
发布日期-字符串;
到期日期-字符串。

注意:1.在此数据中存在在“护照号”字段中包含值X的条目,在“ SIM卡号”中包含值Y的条目分别表示向客户发放了护照号码X的SIM卡号Y。 证明没有为护照号码为X的客户发行了编号为Y的SIM卡。2.可以向一个客户发行多张SIM卡。 因此,可能存在在其字段中具有重复值的数据。

7.客户==SIM卡的发行或归还数据应以循环链表的形式进行组织==,并==按主键“ SIM卡号”的顺序进行排列==。 列表视图和排序方法由作业选项确定。

8.信息系统“移动运营商的客户服务”应执行以下操作:
新客户注册;
客户服务提现
查看所有注册客户
清除客户数据;
通过“护照号”搜索客户 搜索结果-有关找到的客户的所有信息以及发给他的SIM卡号;
客户按全名或地址的片段进行搜索。 搜索结果-找到的客户列表指示护照号码,姓名和地址。

添加新的SIM卡;
删除SIM卡信息
查看所有可用的SIM卡
清除SIM卡数据
通过“ SIM卡号”搜索SIM卡。 搜索结果-有关找到的SIM卡的所有信息,以及该SIM卡发给的客户的姓名和护照号码;
按费率搜索SIM卡。 搜索结果-找到的SIM卡列表,指示“ SIM卡号”,资费,制造年份
向客户发行SIM卡的注册
注册客户返回的SIM卡。

9.查看所有注册客户或查看所有SIM卡时发出的客户或SIM卡数据的组成由学生独立确定,但必须包含至少两个字段

10.由学生独立确定以一定速率搜索SIM卡的方法。 必须将所选方法与替代方法进行比较。

11.通过全名或地址的片段搜索客户端应通过==系统遍历AVL搜索树==来进行。 解决方法由作业选项确定。 在按全名或地址的片段搜索客户端时,可以指定全名或地址及其组成部分(例如,仅客户端的姓氏,不包括名字和中间名,仅地址中的街道名)。 要检测全名或地址中的给定片段,应使用在任务变体中指定的文本中搜索单词的算法。

12.仅当移动运营商拥有SIM卡(相应SIM卡的“可用性标志”字段的值为“ True”)时,才应进行向客户的SIM卡发行注册。

13.在注册向客户发行SIM卡或客户返还SIM卡时,必须调整相应SIM卡的“可用性标志”字段的值。

我的想法(删减修改版)

数据导入与数据存储

MySQL数据库。


功能实现

数据库数据写入AVL树与哈希表。

新客户注册;(AVL树中插入数据)
客户服务提现;(AVL树中主键搜索)
查看所有注册客户;(主键遍历AVL树)
清除客户数据;(AVL树中主键删除)
客户按全名或地址的片段进行搜索。 搜索结果-找到的客户列表指示护照号码,姓名和地址。(AVL中非主键搜索)

添加新的SIM卡;(哈希表主键插入)
删除SIM卡信息;(哈希表主键删除)
查看所有可用的SIM卡;(哈希表主键遍历)
按费率搜索SIM卡。 搜索结果-找到的SIM卡列表,指示“ SIM卡号”,资费,制造年份(哈希表中非主键搜索)

通过“ SIM卡号”搜索SIM卡。 搜索结果-有关找到的SIM卡的所有信息,以及该SIM卡发给的客户的姓名和护照号码;(哈希表主键搜索+AVL树主键搜索)
向客户发行SIM卡的注册。(哈希表主键搜索+AVL树主键搜索)
注销客户的SIM卡。(哈希表主键搜索+AVL树主键搜索)

AVL树与哈希表数据写回数据库。


数据结构

2.有关每个客户端的数据应包含:
护照号码-格式为“ NNNN-NNNNNN”的字符串,其中N为数字;
护照的签发地点和日期-字符串;
名称-字符串;
出生年份-整个;
地址是一个字符串;

注意-线的长度(护照号码除外)由学生独立确定。

3.==客户数据应组织为AVL搜索树==,并==按“护照号”排序==。

4.每个SIM卡的数据必须包含:
SIM卡号码-格式为“ NNN-NNNNNNN”的字符串,其中N是数字
资费是一个字符串
发布年份-整体;
可用性的标志是合乎逻辑的。

用户结构

typedef struct User_Message{
    string passport_number;
    string passport_issue_address;
    string passport_issue_time; 
    string user_name;
    string user_birthday;
    string user_hometown;
}UM_t;

SIM卡结构

typedef struct SIM_Message{
    string SIM_number;
    string last_money;
    string SIM_issue_time;
    int issue_flag;
    string owner_number;    //持卡人护照号码
}SIM_t;

AVL树数据结构

struct User_Tree_Node{
    User_Tree_Node* left;
    User_Tree_Node* right;
    User_Message* data;
}

哈希表结构

underored_map<string,SIM_Message*> hash_SIM;

数据表

用户表

create table UM(
    passport_number varchar(12) primary key,
    passport_issue_address varchar(12) not NULL,
    passport_issue_time varchar(12) not NULL,
    user_name varchar(12) not NULL,
    user_birthday varchar(12),
    user_hometown varchar(12)
);

SIM卡表

create table SIM(
    SIM_number varchar(12) primary key,
    last_money varchar(12) not NULL,
    SIM_issue_time varchar(12) not NULL,
    issue_flag int not NULL,
    owner_number varchar(12) 
);

时间安排

预计用时3天,规划一天,数据库方面一天,数据结构方面一天。
在这里插入图片描述

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
存储 算法 Perl
数据结构实验之链表
本实验旨在掌握线性表中元素的前驱、后续概念及链表的建立、插入、删除等算法,并分析时间复杂度,理解链表特点。实验内容包括循环链表应用(约瑟夫回环问题)、删除单链表中重复节点及双向循环链表的设计与实现。通过编程实践,加深对链表数据结构的理解和应用能力。
65 4
|
12天前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
2月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
74 5
|
2月前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
122 4
|
2月前
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
2月前
|
存储 Web App开发 算法
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法
|
2月前
|
算法
数据结构之购物车系统(链表和栈)
本文介绍了基于链表和栈的购物车系统的设计与实现。该系统通过命令行界面提供商品管理、购物车查看、结算等功能,支持用户便捷地管理购物清单。核心代码定义了商品、购物车商品节点和购物车的数据结构,并实现了添加、删除商品、查看购物车内容及结算等操作。算法分析显示,系统在处理小规模购物车时表现良好,但在大规模购物车操作下可能存在性能瓶颈。
55 0
|
3月前
|
SQL JavaScript 关系型数据库
node博客小项目:接口开发、连接mysql数据库
【10月更文挑战第14天】node博客小项目:接口开发、连接mysql数据库
|
2月前
|
C语言
【数据结构】双向带头循环链表(c语言)(附源码)
本文介绍了双向带头循环链表的概念和实现。双向带头循环链表具有三个关键点:双向、带头和循环。与单链表相比,它的头插、尾插、头删、尾删等操作的时间复杂度均为O(1),提高了运行效率。文章详细讲解了链表的结构定义、方法声明和实现,包括创建新节点、初始化、打印、判断是否为空、插入和删除节点等操作。最后提供了完整的代码示例。
80 0
|
3月前
|
存储
[数据结构] -- 双向循环链表
[数据结构] -- 双向循环链表
30 0

热门文章

最新文章

推荐镜像

更多