一、学习总结


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-栈和队列的更多相关文章

  1. 学习javascript数据结构(一)——栈和队列

    前言 只要你不计较得失,人生还有什么不能想法子克服的. 原文地址:学习javascript数据结构(一)--栈和队列 博主博客地址:Damonare的个人博客 几乎所有的编程语言都原生支持数组类型,因 ...

  2. [ACM训练] 算法初级 之 数据结构 之 栈stack+队列queue (基础+进阶+POJ 1338+2442+1442)

    再次面对像栈和队列这样的相当基础的数据结构的学习,应该从多个方面,多维度去学习. 首先,这两个数据结构都是比较常用的,在标准库中都有对应的结构能够直接使用,所以第一个阶段应该是先学习直接来使用,下一个 ...

  3. 剑指Offer面试题:6.用两个栈实现队列

    一.题目:用两个栈实现队列 题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail和deleteHead,分别完成在队列尾部插入结点和在队列头部删除结点的功能. 原文是使用 ...

  4. C实现栈和队列

    这两天再学习了数据结构的栈和队列,思想很简单,可能是学习PHP那会没有直接使用栈和队列,写的太少,所以用具体代码实现的时候出现了各种错误,感觉还是C语言功底不行.栈和队列不论在面试中还是笔试中都很重要 ...

  5. JavaScript数组模拟栈和队列

    *栈和队列:js中没有真正的栈和队列的类型              一切都是用数组对象模拟的 栈:只能从一端进出的数组,另一端封闭       FILO   何时使用:今后只要仅希望数组只能从一端进 ...

  6. 用JS描述的数据结构及算法表示——栈和队列(基础版)

    前言:找了上课时数据结构的教程来看,但是用的语言是c++,所以具体实现在网上搜大神的博客来看,我看到的大神们的博客都写得特别好,不止讲了最基本的思想和算法实现,更多的是侧重于实例运用,一边看一边在心里 ...

  7. JavaScript中的算法之美——栈、队列、表

    序 最近花了比较多的时间来学习前端的知识,在这个期间也看到了很多的优秀的文章,其中Aaron可能在这个算法方面算是我的启蒙,在此衷心感谢Aaron的付出和奉献,同时自己也会坚定的走前人这种无私奉献的分 ...

  8. Java数据结构和算法之栈与队列

    二.栈与队列 1.栈的定义 栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表. (1)通常称插入.删除的这一端为栈顶(Top),另一端称为栈底(Bottom). (2)当表中没有元素时称为 ...

  9. python数据结构之栈、队列的实现

    这个在官网中list支持,有实现. 补充一下栈,队列的特性: 1.栈(stacks)是一种只能通过访问其一端来实现数据存储与检索的线性数据结构,具有后进先出(last in first out,LIF ...

  10. 栈和队列的面试题Java实现【重要】

    栈和队列: 面试的时候,栈和队列经常会成对出现来考察.本文包含栈和队列的如下考试内容: (1)栈的创建 (2)队列的创建 (3)两个栈实现一个队列 (4)两个队列实现一个栈 (5)设计含最小函数min ...

随机推荐

  1. luogu P1141 01迷宫

    https://www.luogu.org/problem/show?pid=1141 还不太会用 BFS 然后就跟着感觉走了一波 经历了很多错误 刚开始的读入 然后BFS的过程 最后T三个点 看到别 ...

  2. Redis之持久化

    Redis 持久化 提供了多种不同级别的持久化方式:一种是RDB,另一种是AOF. RDB方式的持久化是通过快照(snapshotting)完成的,当符合一定条件时Redis会自动将内存中的所有数据进 ...

  3. 【p4tutorials】P4 v1.1 Simple Router

    fork了p4tutorials,想从里面窥探一些门道. 本文相关的原文链接:ReadMe 说明: 下面的这个P4程序,是当下最著名的 simple_router 程序的一个版本,是根据P4的1.1版 ...

  4. Qt532_WebKit_SSL问题

    1.打开网页"http://www.baidu.com",它会跳转至"https://www.baidu.com/",使用 SSL了,于是 WebView 出现 ...

  5. D3.js学习笔记(六)——SVG基础图形和D3.js

    目标 在这一章,我们将会重温SVG图形,学习如何使用D3.js来创建这些图形. 这里会包括前面例子中的SVG基础图形以及如何使用D3.js设置图形的属性. 使用D3.js画一个SVG 的 圆 circ ...

  6. Java IO流-字节流

    2017-11-05 17:48:17 Java中的IO流按数据类型分类分为两种,一是字节流,二是字符流.字符流的出现是为了简化文本数据的读入和写出操作. 如果操作的文件是文本文件,那么使用字符流会大 ...

  7. 查找一个Class到底在那一个jar文件里

    整理自己的一些笔记,发觉这个命令 ,看起来是用来找一个Class到底在那一个jar文件里的. 虽然没有再测一下,估计是好使的. 先在博客园里记下来,防止自己忘掉. findstr /S /M org. ...

  8. 2-14-2 MySQL数据类型

    MySQL数据类型: 对数据进行分类,针对不同分类进行不同的处理. 1. 使系统能够根据数据类型来操作数据. 2. 预防数据运算时出错. 3. 更有效的利用空间. 数据分类,可以使用最少的存储,来存放 ...

  9. UVA-1343 The Rotation Game (IDA*)

    题目大意:数字1,2,3都有八个,求出最少的旋转次数使得图形中间八个数相同.旋转规则:对于每一长行或每一长列,每次旋转就是将数据向头的位置移动一位,头上的数放置到尾部.若次数相同,则找出字典序最小旋转 ...

  10. Linux修改字符集

    set NLS_LANG=american_america.AL32UTF8-----Linux下查看及更改oracle字符集编码[root@OracleDB ~]# cd /usr/local/or ...