博客作业03–栈和队列

博客作业03–栈和队列

1.学习总结(2分)

1.1 写出你认为本周学习中比较重要的知识点关键词

本章主要学习了栈的顺序储存结构及其基本运算的实现,还有就是栈的链式结构。
其中,包含了进站,出栈等一系列的基本操作,栈这章,还学会一个比较重要的就是
将中缀表达式转成后缀表达式,和迷宫找出路。
队与栈的最大不同点就是:栈是先进后后出,而对是先进先出,队中还有一个较为特别
就是循环队,通过队可以找到迷宫的最短路径,同样队用于一些报数问题的解决也是非常的方便。

2.PTA实验作业(4分)

2.1 题目1:7-1 jmu-字符串是否对称(20 分)

2.2 设计思路(伪代码或流程图)

首先先利用数组a顺序的存放字符串,
同时将这些字符串进栈。
while(top>字符串长度的一半时){

if(栈顶元素=a[i]){

出栈 ,i++;
else 返回错误;
}

2.3 代码截图(注意,截图、截图、截图。代码不要粘贴博客上。不用用···语法去渲染)

主函数:
1233828-20180414112352235-1725774989.png

进栈与判断函数:
1233828-20180414112501610-271290953.png

2.4 PTA提交列表说明。

1233828-20180414112805613-1764909519.png

7-1 jmu-报数游戏(15 分)

2.2 设计思路(伪代码或流程图)

将所有的数字按顺序进队
for( int i=1 ; NumOff.size() > 1 ; i++ )
if(i对m取余==0) 输出队顶元素,出队。
else{

记录队顶元素,让队顶元素出队再进队。
}

2.3 代码截图(注意,截图、截图、截图。代码不要粘贴博客上。不用用···语法去渲染)

1233828-20180414114831440-1474198280.png

2.4 PTA提交列表说明。

1233828-20180414115008186-735954601.png

之前,我是选择用循环队来做的,结果很绕,当时这题绕了很久,做了那么久也就是m>n的那个点对了,
思路是让队顶和队尾后移,直到m处,出队并打印。直到队尾空。当初是这个思路可惜没有实现。

7-3 银行排队问题之单队列多窗口服务(25 分)

2.2 设计思路(伪代码或流程图)

先让所有的人排成一只队伍,
定义数组a[k]表示窗口,初始化窗口=0;
while(队位空){

for(i=0 to i=k){

寻找最小那个窗口的下标,说明这个窗口的人最快结束。
记为L
}
出队 对头
if(队头的人的到达时间t>a[L],说明此人不用排队)
让此人进入此窗口,a[L]=此人来的时间加上操作的时间.
else {

说明此人需要等待
wait 记录等待时间,
在让此人进入窗口
a[L]=a[L]+操作的时间。
}//就这两种情况。
}
}

2.3 代码截图(注意,截图、截图、截图。代码不要粘贴博客上。不用用···语法去渲染)

主函数:

1233828-20180414220819590-1302445487.png

1233828-20180414220918149-1913045591.png

其他进出队的函数:
1233828-20180414221015112-596494829.png

2.4 PTA提交列表说明

1233828-20180414221110874-1019810516.png

第一次错误:
1233828-20180414221201039-181594957.png

这次的错误主要是:假设在1号和2号都空闲的时候,而此时2号窗口的时间更小,按照以上思路会选择2号窗口,
然而题目要求,在窗口都能够选择的时候,应该选择窗口号较小的。所以问题出在这,
改正方法是:在寻找窗口时间最小的for 循环中 加入一条判断 if(此时客户到达的时间>此窗口的时间)退出这个循环。

3.截图本周题目集的PTA最后排名(3分)

3.1 栈PTA排名

1233828-20180414222105165-855635131.png

3.2 队列PTA排名

1233828-20180414222227961-738120131.png

3.3 我的总分:205

4. 阅读代码(必做,1分)

 void algo3(Queue &Q){
    Stack S;
    int d;
    InitStack(S);
    while(!QueueEmpty(Q))
    {
        DeQueue(Q, d);
        Push(S, d);
    }
    while(!StackEmpty(S)) {
        Pop(S, d);
        EnQueue(Q, d);
    }
}

此代码是将队与栈巧妙的结合来将,线性表倒序,
充分的利用了队与栈的不同行。

5. 代码Git提交记录截图

转载于:https://www.cnblogs.com/1028-zwj/p/8824958.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101719.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • win10无法安装华为电脑管家_非华为电脑怎么下载华为电脑管家

    win10无法安装华为电脑管家_非华为电脑怎么下载华为电脑管家一、准备内容①华为电脑下载华为电脑管家

    2022年8月13日
    10
  • 三种方法求逆矩阵_列举出求逆矩阵的三个方法

    三种方法求逆矩阵_列举出求逆矩阵的三个方法求出逆矩阵的2种手算方法:待定系数法、伴随矩阵法待定系数法求逆矩阵:首先,我们来看如何使用待定系数法,求矩阵的逆。举例:矩阵A=12-1-3假设所求的逆矩阵为abcd则从而可以得出方程组a+2c=1b+2d=0-a-3c=0-b-3d=1解得a=3b=2c=-1d=-1所以A的逆矩阵A⁻¹=32-1-1伴随矩阵求逆矩阵:伴随矩阵是矩阵元素所对应的代数余子式,所构成的矩阵,转置后得到的新矩阵。我们先求出伴随矩阵A*=-3-211接下来,

    2022年8月21日
    4
  • FileZilla出现Failed to convert command to 8 bit charset

    FileZilla出现Failed to convert command to 8 bit charset

    2021年10月7日
    50
  • mysql 环境_MySQL怎么配置环境变量?「建议收藏」

    mysql 环境_MySQL怎么配置环境变量?「建议收藏」安装完MySQL后,如果不配置环境变量的话,每次还要转到mysql/bin目录下才能操作,下面本篇文章就来给大家介绍一下如何配置环境变量,希望对大家有所帮助。MySQL配置环境变量的步骤:1、右键【我的电脑】,选择【属性】2、选择左侧的【高级系统设置】3、在弹出的窗口点击右下角【环境变量】4、点击新建,在弹出窗口变量名输入mysql_home,变量值输入你的mysql安装路径,如图:5、编辑Pat…

    2022年6月18日
    32
  • 手游市场数据分析_梦幻西游手游考古3进4

    手游市场数据分析_梦幻西游手游考古3进4“机”不离手是大多数人的生活状态,甚至有一个用手机形容真爱的段子:“在一起时不看手机,不在一起时秒回信息,就算现代人的真爱了。”随着手机在日常生活中地位的提升,手机游戏也逐渐成为年轻人日常生活不可或缺的一部分。 在7月31日的网易云创大会游戏论坛上,来自TalkingData华南区业务负责人黎丽华给大家带来了“透过数据看真相:手游市场趋势报告”的主题分享。通过一些鲜活的数据向大家展示了…

    2025年6月21日
    3
  • 群晖aria2外网无法访问(群晖设置aria2)

    NAS群晖DSM5.2小白教程:一行命令用Docker架设aria2服务首发2016-05-1712:15:2225点赞285收藏57评论小编注:此篇文章来自即可瓜分10万金币,周边好礼达标就有,邀新任务奖励无上限,点击查看活动详情群晖DSM5.2起新增支持Docker让开发者与用户能以最少的时间与资源,能够在Synology服务器上部署和运行大量应用程序。Docker容器和普通的虚…

    2022年4月14日
    802

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号