求解数据结构栈的输出输入问题

问题描述

求解数据结构栈的输出输入问题


为何结果是stack?pop(s,x)的用法是什么?
O(∩_∩)O谢谢

解决方案

Pop(S,x)就是把栈S中的元素弹出来,放到x中。(不过不知道是用什么Pop是用什么方式实现的,像这样按值传递可以在Pop里改变x吗?)

1.Push(S,x);Push(S,'a');Push(S,y);
之后栈为:kac;
2.Pop(S,x);
之后栈为:ac;x=k;
3.Push(S,'t');Push(S,x)
之后栈为:ktac;
4.Pop(S,x)
之后栈为:tac;x=k;
5.Push(S,'s')
之后栈为:stac;
6.后面的while循环里将栈里的字符逐个Pop出来输出就是"stac"
7.最后的printf(x)(这是什么用法?C语言可以这用?)输出x里面的"k"

解决方案二:

脑补下,pop(s, x)应该是pop(Stack s, char& x),通过第二个参数来传出栈顶内容。
push就是把一个字符送入栈顶,pop就是删除栈顶元素,并且返回。
第一行
[] -> c -> ca -> cak
第二行
cak -> ca -> cat -> catk
第三行
catk -> cat -> cats
最后出栈stac,注意最后一次pop(s, x)出栈了k,所以最后输出x又输出了k
结果是stack

解决方案三:

pop就是对栈s,弹出栈顶元素到x中,其实就是个函数吧,一般都是s.pop

时间: 2024-08-29 21:18:48

求解数据结构栈的输出输入问题的相关文章

数据结构栈实现进制转换遇到问题十进制数255 输出的十六进制数是F15F15 哪里错了

问题描述 数据结构栈实现进制转换遇到问题十进制数255 输出的十六进制数是F15F15 哪里错了 //进制转换函数 void conversion(int n,int r) { SqStack S;//构建一个栈 InitStack(S); while(n) { Push(S,n%r);//数据入栈 n=n/r; } while(!StackEmpty(S)) { SElemType e; Pop(S,e);//数据出栈 switch(e) { case 0: break; case 1: br

新手 菜鸟 问题-求解数据结构课程设计问题

问题描述 求解数据结构课程设计问题 学生成绩管理系统 设计目的: 1 掌握线性链表的建立. 2 掌握线性链表的基本操作. 3 掌握查找的基本算法. 设计内容: 利用线性链表实现学生成绩管理系统,具体功能:输入.输出.插入.删除.查找.追加.读入.显示.保存.拷贝.排序.索引.分类合计.退出,并能在屏幕上输出操作前后的结果. 设计要求: 1 写出系统需求分析,并建模. 2 编程实现,界面友好. 3 输出操作前后的结果. 解决方案 建立一个类/结构体 student s{ str Name; str

数据结构――栈、队列和树(Java)

数据|数据结构 数据结构――栈.队列和树 开发者可以使用数组与链表的变体来建立更为复杂的数据结构.本节探究三种这样的数据结构:栈.队列与树.当给出算法时,出于简练,直接用Java代码. 栈 栈是这样一个数据结构,其数据项的插入和删除(获取)都只能在称为栈顶的一端完成.因为最后插入的数据项就是最先要删除的数据项,开发者往往将栈称为LILO(last-in, first-out)数据结构. 数据项压入(插入)或者弹出(删除或取得)栈顶.图13示例了一个有三个String数据项的栈,每个数据项压入栈顶

帮忙写个数据结构栈的 谢谢

问题描述 帮忙写个数据结构栈的 谢谢 1.从键盘上输入表达式. 2.分析该表达式是否合法: (1)是数字,则判断该数字的合法性.若合法,则压入数据到堆栈中. (2)是规定的运算符,则根据规则进行处理.在处理过程中,将计算该表达式的值. (3)若是其它字符,则返回错误信息. 3.若上述处理过程中没有发现错误,则认为该表达式合法,并打印处理结果. 解决方案 http://wenku.baidu.com/link?url=UQoesURrEsUM4NvE5ZacHn8kAk5HgZTj5uMfmZEg

关于数据结构栈的赋值

问题描述 关于数据结构栈的赋值 #include using namespace std; typedef int SElemType; //???????????????ù???????? #define STACK_INIT_SIZE 100 //?¨???????????±??×??ó?? #define STACKINCREMENT 10 //?¨???????????????????????ó?? typedef struct{ SElemType *base; //?¨???á???

PHP SPL标准库之数据结构栈(SplStack)介绍

  这篇文章主要介绍了PHP SPL标准库之数据结构栈(SplStack)介绍,栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈),需要的朋友可以参考下 栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈) SplStack就是继承双链表(SplDoublyLinkedList)实现栈. 类摘要如下: 简单使用如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18

数据结构 栈的基本操作 进制转换 为什么运行后会陷入死循环

问题描述 数据结构 栈的基本操作 进制转换 为什么运行后会陷入死循环 ```#include #include #include #define OK 1 #define ERROR -1 #define OVERFLOW -1 #define ENDFLAG 0 #define STACK_INIT_SIZE 100//初始分配量 #define STACKINCREMENT 10//增量 typedef int Status; typedef int SElemType; typedef s

PHP SPL标准库之数据结构栈(SplStack)介绍_php实例

栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈) SplStack就是继承双链表(SplDoublyLinkedList)实现栈. 类摘要如下: 简单使用如下: //把栈想象成一个颠倒的数组 $stack = new SplStack(); /** * 可见栈和双链表的区别就是IteratorMode改变了而已,栈的IteratorMode只能为: * (1)SplDoublyLinkedList::IT_MODE_LIFO | SplDoublyL

c++-数据结构 栈的定义 栈的定义

问题描述 数据结构 栈的定义 栈的定义 定义:栈是限定仅在表头进行插入和删除操作的线性表. 栈定义用的是数组 那为什么只能在头插入和删除 实际上到底什么啊 解决方案 只能在栈顶操作只是栈的定义要求是这样的,这样就实现了"先进后出"的效果.你应该发现普通链表.栈.队列这三种结构本质是相同的,只是人为规定只能在一端或者两端操作. 你如果直接对栈底进行操作,当然是可以的,只是这种数据结构已经不能称之为"栈"了. 如果从编程角度来说的话,假设栈是一个类,那么这个类只提供了p