Data_Structure03-栈和队列
一、学习总结
1、写出你认为本周学习中比较重要的知识点关键词
·抽象数据类型
·栈和队列
2、思维导图

二、PTA实验作业
选题:
1、7-1 jmu-字符串是否对称(20 分)
2、7-4(选做) 列车厢调度(25 分)
3、7-2 银行业务队列简单模拟(25 分)
题目1:7-1 jmu-字符串是否对称
1、设计思路
#头文件
int main(){
定义字符串 c;
输入字符串;
定义字符型栈ch;
定义整型变量 len,i,a;
len <- c.size();
i <- 0;
a <- len%2;
if !a //偶数个
then while i小于len
do if i小于len/2 //进栈
then c[i]进栈
elseif c[i]等于栈顶
then 栈顶出栈
else
then 输出no
return 0;
i++;
end
else //奇数个
then while i小于len
do if i小于len/2 //进栈
then c[i]进栈
elseif c[i]等于栈顶
then 栈顶出栈
else
then 输出no
return 0;
if i等于len/2-1
then i++;
i++;
end
输出yes
return 0;
}
2、代码截图


3、PTA提交列表说明

编译错误:把编译器改成C++;
运行超时:一开始我是输入一个字符则进栈一个字符,结果运行超时,后来,修改成一次性输入字符串在进行判断。
题目2:7-4(选做) 列车厢调度
1、设计思路
#头文件
int main(){
定义整型变量 i<-0,j<-0;
定义字符型数组 a,b,res,res2;
定义字符型栈s;//用于储存轨道3的列车
输入 a,b;
while a[i]
do if a[i]==b[j]
then res[j++]<-a[i];
i++;
continue;
while s不为空&&s栈顶不等于b[j]
do res[j]<-b[j]
j++;
删除栈顶
end
if a[i]不等于b[j]
then a[i]进栈
i++
end
//将轨道3上的列车全部移向轨道2
while 栈s不为空
do res[j++]<-栈顶
删除栈顶
end
if res与b不同
then 输出“Are you kidding me?"
return 0;
i<-j<-0;
//如果res与b相同,则重复上述操作输出操作序列
while a[i]
do if a[i]==b[j]
then res2[j++]<-a[i];
i++;
输出 "1->2" 且换行
continue;
while s不为空&&s栈顶不等于b[j]
do res2[j]<-b[j]
j++;
输出 "3->2" 且换行
删除栈顶
end
if a[i]不等于b[j]
输出 "1->3" 且换行
then a[i]进栈
i++
end
while 栈s不为空
do res2[j++]<-栈顶
删除栈顶
输出 "3->2" 且换行
end
return 0;
}
2、代码截图



3、PTA提交列表说明

编译错误:代码中使用了gets()来输入字符串,头文件中的定义中没有,后来改用头文件#include <bits/stdc++.h> ,该头文件包括了所有的头文件,不用写太多的头文件
题目3:7-2 银行业务队列简单模拟
1、设计思路
#头文件
int main(){
定义整型变量 temp,n,i<-0;
输入n;
定义队列A,B;
for i<-0 to n
do 输入temp
if temp为奇数
then 进A队列
else //temp为偶数
then 进B队列
end
//为了输出中间的空格,先输出一个
if A队列不为空
then 输出A队列头
删除A队列头
i++
else
then 输出B队列头
删除B队列头
while A队列不为空并且B队列不为空
do i++;
if i%2
then if A队列不为空
then 输出” ”和A的队列头
删除A队列头
else
if A队列不为空
then 输出” ”和A的队列头
删除A队列头
if B
then 输出” ”和B的队列头
删除B队列头
end
输出回车
return 0;
}
2、代码截图


3、PTA提交列表说明

编译错误:编译器为改成C++
部分正确:在输出第一个元素的时候,在B队列那里输出完后没有删除
三、本周题目集的PTA最后排名
1、栈PTA排名

2、队列PTA排名

3、我的总分:2.5
四、阅读代码
码云地址



功能:实现多项式A与多项式B的相除并输出商和余
优点:逻辑结构清晰,易于阅读;代码简洁;
五、代码Git提交记录截图

Data_Structure03-栈和队列的更多相关文章
- 学习javascript数据结构(一)——栈和队列
前言 只要你不计较得失,人生还有什么不能想法子克服的. 原文地址:学习javascript数据结构(一)--栈和队列 博主博客地址:Damonare的个人博客 几乎所有的编程语言都原生支持数组类型,因 ...
- [ACM训练] 算法初级 之 数据结构 之 栈stack+队列queue (基础+进阶+POJ 1338+2442+1442)
再次面对像栈和队列这样的相当基础的数据结构的学习,应该从多个方面,多维度去学习. 首先,这两个数据结构都是比较常用的,在标准库中都有对应的结构能够直接使用,所以第一个阶段应该是先学习直接来使用,下一个 ...
- 剑指Offer面试题:6.用两个栈实现队列
一.题目:用两个栈实现队列 题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail和deleteHead,分别完成在队列尾部插入结点和在队列头部删除结点的功能. 原文是使用 ...
- C实现栈和队列
这两天再学习了数据结构的栈和队列,思想很简单,可能是学习PHP那会没有直接使用栈和队列,写的太少,所以用具体代码实现的时候出现了各种错误,感觉还是C语言功底不行.栈和队列不论在面试中还是笔试中都很重要 ...
- JavaScript数组模拟栈和队列
*栈和队列:js中没有真正的栈和队列的类型 一切都是用数组对象模拟的 栈:只能从一端进出的数组,另一端封闭 FILO 何时使用:今后只要仅希望数组只能从一端进 ...
- 用JS描述的数据结构及算法表示——栈和队列(基础版)
前言:找了上课时数据结构的教程来看,但是用的语言是c++,所以具体实现在网上搜大神的博客来看,我看到的大神们的博客都写得特别好,不止讲了最基本的思想和算法实现,更多的是侧重于实例运用,一边看一边在心里 ...
- JavaScript中的算法之美——栈、队列、表
序 最近花了比较多的时间来学习前端的知识,在这个期间也看到了很多的优秀的文章,其中Aaron可能在这个算法方面算是我的启蒙,在此衷心感谢Aaron的付出和奉献,同时自己也会坚定的走前人这种无私奉献的分 ...
- Java数据结构和算法之栈与队列
二.栈与队列 1.栈的定义 栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表. (1)通常称插入.删除的这一端为栈顶(Top),另一端称为栈底(Bottom). (2)当表中没有元素时称为 ...
- python数据结构之栈、队列的实现
这个在官网中list支持,有实现. 补充一下栈,队列的特性: 1.栈(stacks)是一种只能通过访问其一端来实现数据存储与检索的线性数据结构,具有后进先出(last in first out,LIF ...
- 栈和队列的面试题Java实现【重要】
栈和队列: 面试的时候,栈和队列经常会成对出现来考察.本文包含栈和队列的如下考试内容: (1)栈的创建 (2)队列的创建 (3)两个栈实现一个队列 (4)两个队列实现一个栈 (5)设计含最小函数min ...
随机推荐
- Openldap基于digest-md5方式的SASL认证配置
1. openldap编译 如果需要openldap支持SASL认证,需要在编译时加上–enable-spasswd选项安装完cyrus-sasl,openssl(可选),BDB包后执行: 1 2 $ ...
- 下载百度网盘破解 获得 所下载视频URL 粘贴到thunder
Chrome:方法1. 进入谷歌商城,搜索baidudl.安装即可. 方法2. 下载baidudl.zip.解压获得baidudl文件夹.进入chrome://extensions/,勾选右上角Dev ...
- MaintainableCSS 《可维护性 CSS》 --- 约定篇
约定 可维护的CSS具有以下约定: .<module>[-<component>][-<state>] {} 根据所讨论的模块,方括号是可选的.这里有些例子: /* ...
- SQLPLUS的乱码问题
我的中文系统,把对应非unicode字符时的设置,改成了 日文, 结果控制台使用sqlplus时候,总是出现乱码. 解决方法是,把NLS_LANG环境变量变成跟系统一样,就可以了. american_ ...
- DataReader 绑定DataGridView有两种方式
第一种:借助于BindingSourcesqlDataReader Sdr=通过查询函数得到的sqlDataReader类型的数据;BindingSource Bs=new BindingSource ...
- C#对象初始或器-Chapter3 P38
protected string GetMessage() { //如何构造和初始化泛型集合库中的一个数组和两个类. Product myProduct = ,Name="Kayak&quo ...
- APP的六种loading加载样式,全在这...
今天这篇文章是给大家分享的loading加载的设计,文章里面会有一些实例在这分享给大家! 大多数App都要与服务器进行数据的交换,App向服务器发出数据请求,服务器接收到请求之后向App传输相应数据, ...
- sgu 137. Funny Strings 线性同余,数论,构造 难度:3
137. Funny Strings time limit per test: 0.25 sec. memory limit per test: 4096 KB Let's consider a st ...
- tortoiseGIT保存用户名密码
虽然GIT可以使用SSH来免去输入用户名密码的麻烦,但是更多的人我相信还是比较喜欢使用tortoiseGIT. 使用HTTP模式的代码库可以通过保存用户名密码的方式来免去重复输入的麻烦. 首先安装gi ...
- 选择语句=》OO函数实现
let a; let b; if (a==="A") { b='定向' }else if (a==='B') { b='开放' }else if(a==='C') { b='全部' ...