算法训练1.0:写一个排队系统

简介: 要求的功能

要求的功能:


9d2b2889b1dfe361a8c40f4374f5c2e.png


需求分析:

1.首先看图片分析一下有哪些功能,如下所示:

a.第一个功能,添加学生,输入添加人数;

b.第二个功能,安排就餐;

c.第三个功能,在指定位置之前插入新的客人;

d.第四个功能,删除指定位置的客人信息;

e.第五个功能,查找给定姓名,返回在队伍中的位置;

f.第六个功能,用学号进行排序;

g.第七个功能打印所有客户信息;

h.就是退出功能;

2.除此之外,还要再写两个功能:

i.展示开头和末尾的学生;

j.展示初始页面;

通过输入相应的序号,来达到相应的效果;

3.功能实现:

a.在已存在的线性表,输入学生的姓名和学号;每输入一个学生,长度要加一;

void ListAdd(SqList &L,int n)
{
for(int i=1;i<=n;i++)
{
    People Q;
cout <<"请输入该学生的姓名:"<<endl;
cin >>Q.sn;
cout <<"请输入该学生的卡号:"<<endl;
cin >>Q.si;
        L.stu[L.length]=Q;
        ++L.length;
}
}

b.这个功能简单来说就是删除第一个元素,后面的元素向前移动,或者直接通过遍历覆盖第一个元素;

要注意的是长度要减一;

void ListTop(SqList &L)
{
for(int i=0;i<L.length-1;i++)
{
    L.stu[i]=L.stu[i+1]; 
}
L.length--;
}

c.这个不难,和书上的一样,要注意插入的位置范围与数组的最大长度,如果超过或者不符合范围要注意插入失败;

string ListInsert(SqList &L,int i,People e)
{
if((i<1)||(i>L.length+1)) return "插入失败!输入的范围错误!";
if(L.length==MAXSIZE)  return "插入失败!";
for(int j=L.length-1;j>=i-1;j--)
{
    L.stu[j+1]=L.stu[j];
}
L.stu[i-1]=e;
++L.length;
return "插入成功"; 
}

d.这个功能也不难实现,书上也有,同样要注意删除的位置范围;

string ListDelete(SqList &L,int i)
{
if((i<1)||(i>L.length))  return "删除失败!要删除的学生不在范围内!";
for(int j=i;j<=L.length-1;j++)
{
    L.stu[j-1]=L.stu[j];
}
--L.length;
return "删除成功!";
}

e.这个也不是很难,通过遍历,来查找这个学生是否在数组内;

int LocateList(SqList L,string e)
{
for(int i=0;i<L.length;i++)
{
if(L.stu[i].sn==e)
    {
return i+1;
    }
}
return 0;
}

f.这个功能就是遍历,通过学号的大小,进行排序;

void SortList(SqList &L)
{
int i,j;
for(i=0;i<L.length;i++)
{
for(j=i+1;j<L.length;j++)
    {
if(L.stu[i].si>L.stu[j].si)
        {
            People temp=L.stu[i];
            L.stu[i]=L.stu[j];
            L.stu[j]=temp;
        }
    }
}
}

g.这个就很简单了,单纯的打印输出所有的客户,遍历;

int DaYinList(SqList L)
{
for(int i=0;i<L.length;i++)
{
cout <<L.stu[i].sn <<L.stu[i].si <<endl;
}
}

h.这个功能不需要专门写一个函数,只要在主函数内判断一下就行了

i.这个功能就是输出第一个元素与最后一个元素;

void KaimoList(SqList L)
{
if(L.length>0)
{
cout <<L.stu[0].sn<<L.stu[0].si<<endl;
cout <<L.stu[L.length-1].sn<<L.stu[L.length-1].si<<endl;
}else{
cout <<"现在无人员就餐!"<<endl;
}
}

j.这个功能非常重要,但是不难写;

void ZhanshiList(SqList L)
{
cout <<"队内的人数:"<<L.length <<endl;
KaimoList(L);     
cout <<"------------------------"<<endl;
cout <<"1.新增排队人员信息"      <<endl;
cout <<"2.安排客人就餐"          <<endl;
cout <<"3.指定位置插入客人"      <<endl;
cout <<"4.删除指定的位置"        <<endl;
cout <<"5.查找客人信息"          <<endl;
cout <<"6.按照卡号对信息进行排号"<<endl;
cout <<"7.打印所有信息"          <<endl;
cout <<"8.退出"                  <<endl;
cout <<"请输入您选择的功能序号:"<<"";
}

效果图:


249f59eca439286ef7ae92362ecec01.png


4.逻辑实现(主函数),单个的功能写着简单,逻辑实现要好好想一下,并且自己要好好测试一下,看看有啥BUG没有,这一步非常重要;

int main(void)

{

int n;
SqList L;
InitList(L);    //初始化线性表
ZhanshiList(L); //展示初始页面
cin >>n;       //输入第一次要的功能
while(n>-1&&n<9) //判断n的范围,对应相应的功能
{
if(n==1)
    {
        ListAdd(L,1);
    }else if(n==2)
    {
        ListTop(L);
    }else if(n==3)
    {
int i;
        People e; 
cout<<"请输入你要插的位置:"<<endl;
cin >>i;
cout <<"请输入该学生的姓名:"<<endl; 
cin >>e.sn;
cout <<"请输入学生的卡号:" <<endl;
cin >>e.si; 
cout<<ListInsert(L,i,e)<<endl;
    }else if(n==4)
    {
int i;
cout<<"请输入你要删除的位置:"<<endl;
cin >>i;
cout<<ListDelete(L,i)<<endl;
    }else if(n==5)
    {
string e;
cout <<"请输入你要查找的人:"<<endl;
cin >>e;
int a=LocateList(L,e);
cout <<"这个人排第"<<a<<"位"<<endl;
    }else if(n==6)
    {
        SortList(L);
        DaYinList(L);
    }else if(n==7)
    {
        DaYinList(L);
    }else if(n==8)  //这个就是第八个功能,直接退出循环就行了,就能实现;
    {
break;
    }
    ZhanshiList(L); //每一次都要展示初始页面;
cin >>n;  //再次输入n的值;
}
return 0;

}

目录
相关文章
|
1月前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
130 5
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
|
2月前
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
348 55
|
2天前
|
算法
基于电导增量MPPT控制算法的光伏发电系统simulink建模与仿真
本课题基于电导增量MPPT控制算法,使用MATLAB2022a的Simulink进行光伏发电系统的建模与仿真,输出系统电流、电压及功率。电导增量调制(IC)算法通过检测电压和电流变化率,实时调整光伏阵列工作点,确保其在不同光照和温度条件下始终处于最大功率输出状态。仿真结果展示了该算法的有效性,并结合PWM技术调节逆变流器占空比,提高系统效率和稳定性。
|
2月前
|
存储 缓存 监控
局域网屏幕监控系统中的Python数据结构与算法实现
局域网屏幕监控系统用于实时捕获和监控局域网内多台设备的屏幕内容。本文介绍了一种基于Python双端队列(Deque)实现的滑动窗口数据缓存机制,以处理连续的屏幕帧数据流。通过固定长度的窗口,高效增删数据,确保低延迟显示和存储。该算法适用于数据压缩、异常检测等场景,保证系统在高负载下稳定运行。 本文转载自:https://www.vipshare.com
132 66
|
24天前
|
存储 监控 算法
内网监控系统之 Go 语言布隆过滤器算法深度剖析
在数字化时代,内网监控系统对企业和组织的信息安全至关重要。布隆过滤器(Bloom Filter)作为一种高效的数据结构,能够快速判断元素是否存在于集合中,适用于内网监控中的恶意IP和违规域名筛选。本文介绍其原理、优势及Go语言实现,提升系统性能与响应速度,保障信息安全。
28 5
|
2月前
|
机器学习/深度学习 人工智能 算法
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
宠物识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了37种常见的猫狗宠物种类数据集【'阿比西尼亚猫(Abyssinian)', '孟加拉猫(Bengal)', '暹罗猫(Birman)', '孟买猫(Bombay)', '英国短毛猫(British Shorthair)', '埃及猫(Egyptian Mau)', '缅因猫(Maine Coon)', '波斯猫(Persian)', '布偶猫(Ragdoll)', '俄罗斯蓝猫(Russian Blue)', '暹罗猫(Siamese)', '斯芬克斯猫(Sphynx)', '美国斗牛犬
220 29
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
|
1月前
|
算法
基于爬山法MPPT最大功率跟踪算法的光伏发电系统simulink建模与仿真
本课题基于爬山法MPPT算法,对光伏发电系统进行Simulink建模与仿真。使用MATLAB2022a版本,通过调整光伏电池的工作状态以实现最大功率输出。爬山法通过逐步优化工作点,确保光伏系统在不同条件下均能接近最大功率点。仿真结果显示该方法的有效性,验证了模型的正确性和可行性。
|
2月前
|
监控 算法 JavaScript
基于 Node.js Socket 算法搭建局域网屏幕监控系统
在数字化办公环境中,局域网屏幕监控系统至关重要。基于Node.js的Socket算法实现高效、稳定的实时屏幕数据传输,助力企业保障信息安全、监督工作状态和远程技术支持。通过Socket建立监控端与被监控端的数据桥梁,确保实时画面呈现。实际部署需合理分配带宽并加密传输,确保信息安全。企业在使用时应权衡利弊,遵循法规,保障员工权益。
51 7
|
2月前
|
机器学习/深度学习 缓存 人工智能
【AI系统】QNNPack 算法
QNNPACK是Marat Dukhan开发的量化神经网络计算加速库,专为移动端优化,性能卓越。本文介绍QNNPACK的实现,包括间接卷积算法、内存重排和间接缓冲区等关键技术,有效解决了传统Im2Col+GEMM方法存在的空间消耗大、缓存效率低等问题,显著提升了量化神经网络的计算效率。
56 6
【AI系统】QNNPack 算法
|
2月前
|
存储 人工智能 缓存
【AI系统】Im2Col 算法
Caffe 作为早期的 AI 框架,采用 Im2Col 方法优化卷积计算。Im2Col 将卷积操作转换为矩阵乘法,通过将输入数据重排为连续内存中的矩阵,减少内存访问次数,提高计算效率。该方法首先将输入图像转换为矩阵,然后利用 GEMM 库加速计算,最后将结果转换回原格式。这种方式显著提升了卷积计算的速度,尤其适用于通道数较多的卷积层。
70 5
【AI系统】Im2Col 算法

热门文章

最新文章