首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

判断栈的出栈顺序合法性

栈的出栈顺序合法性是指给定一系列元素,如1 - N,按照从小到大的方式入栈,每个元素的出栈时机不定。题目给定一个出栈顺序,我们来判断这个出栈顺序有没有可能发生。...比如对[1,2,3,4,5,6,7,8,9]: [1,2,3,4,5,6,7,8,9]是一个合法出栈序列 [9,8,7,6,5,4,3,2,1]也是一个合法序列 [4,5,3,2,7,6,1,8,9]也是一个合法序列...[3,4,5,1,2,9,8,7,6]就是一个非法序列 判断方法有两种,一种是对每一个值,其后所有小于它的值的数是一个降序排列。...另一种是模拟入栈和出栈,对出栈序列中每一个数值,如果它当前已经在栈顶,则出栈;如果不在,那么从入栈序列中取出下一个放入栈中;如果需要入栈时入栈序列已空,则这就是一个非法序列。...static boolean stackOrder(int[] nums){ int[] origin=new int[]{1,2,3,4,5,6,7,8,9}; //假定出栈序列也是

3.3K41

2-10 出栈序列的合法性 (20 分)

本文链接:https://blog.csdn.net/shiliang97/article/details/101147545 2-10 出栈序列的合法性 (20 分) 给定一个最大容量为 M 的堆栈...,将 N 个数字按 1, 2, 3, ..., N 的顺序入栈,允许按任何顺序出栈,则哪些数字序列是不可能得到的?...输入格式: 输入第一行给出 3 个不超过 1000 的正整数:M(堆栈最大容量)、N(入栈元素个数)、K(待检查的出栈序列个数)。最后 K 行,每行给出 N 个数字的出栈序列。...输出格式: 对每一行出栈序列,如果其的确是有可能得到的合法序列,就在一行中输出YES,否则输出NO。...5 7 5 ,两个五的参数读入读反了,(都怪我没读题呀~) 判断合法性用一个模拟堆栈就行了 #include using namespace std; int a,b,c,n,zhan

74030
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C语言栈的实现

    因为方便:试想一下我们要判断栈是否空就只需要判断top是否等于buttom,如果buttom指向栈底显然就会麻烦许多 下面我们先用C语言来实现一下: 首先我们需要对这个装东西的“盒子”定义,而这个盒子就是栈...{ node *n=new node; n->data=p; n->next=sk->top; sk->top=n; } 出栈 出栈一般有两种:1.让指定数据出栈2.让top指向的数据出栈,注意...,如果要让指定的数据出栈,而且如果那个数据在中间,那你就不得不把从top到那个数据的全部节点出栈,因为栈是后进先出,而且只允许一段入/出,这里我们讨论把top指向的节点出栈 这个非常简单,你可能会马上想到...sk->top=sk->top->next; 但是如果再想一下,你虽然完成了出栈,但是出了栈的那个节点怎么办?...*n=sk->top; sk->top=n->next; delete n; } 就像上面,另还要注意出栈需要考虑栈是否为空,我没有写 至此,一个C语言版本的栈及其主要操作就完成了,这也是我第一次写栈结构

    3.9K40

    C语言共享栈

    栈的操作我相信大家都应该了解了弄懂了, 如果没弄懂希望可以去再去看看相关的资料,我博客中的C语言中缀表达式转后缀表达式中涉及到了一下栈的基本操作,有兴趣的朋友也可以看看。...所谓共享栈,就是两个栈共同使用一块内存空间,其中一个栈的栈底作为另一个栈的栈顶,反之亦然。...如若入栈成功则返回0;入栈失败则返回-1; 出栈时,先确定栈号是否合法,然后查看是对0#栈还是1#栈进行操作,出栈操作和顺序栈的出栈操作并无太大不同。 选定之后进行出栈操作。...如果出栈成功返回0;出栈失败返回-1; 添加适当的头文件,定义一个栈数据结构, 共享栈也是栈,只不过有点特殊,在这里我们还是需要添加适当的头文件和定义恰当的数据结构 #include出栈和入栈一样,也需要选择出栈的具体是哪个栈 int Pop(SqStack *s, ElemType* x, int n) { if (n 1) { printf("The

    1.2K30

    c语言实现栈(顺序栈,链栈)

    个人主页: :✨✨✨初阶牛✨✨✨ 推荐专栏: C语言进阶 个人信条: 知行合一 本篇简介:>:讲解用c语言实现:“数据结构之"栈”,分别从"顺序栈"和"链栈"的接口讲解....栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。 压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。 出栈:栈的删除操作叫做出栈。...出数据也在栈顶 "栈"的常见接口实现 InitST:初始化栈 STPush:入栈 STPop:出栈 STEmpty:判空(判断是否为空栈) PrintSTTop:打印栈顶元素 STTop:返回栈顶元素...同时为了提高效率: 链表 分析 尾插,尾删 效率低,因为需要找尾巴 头插,头插 效率高,只需要改变头指针的指向 综上:我们利用不带头单链表的"头插(入栈)和头删(出栈)"来完成栈的各项基本操作.并且...next指针指向原"栈"的顶点 *pps = newnode;//更新栈顶 } 2.3 “出栈”,删除"栈"中的数据 步骤:(与链表的头删操作类似) 判空,防止空链栈的删除操作 记录原栈顶元素的地址.

    30920

    【C语言】深入浅出:C语言链表的全面解析

    下面我们将详细讲解C语言中单链表、双向链表和循环链表的基本概念、实现方法及其相关操作。...应用 常用于实现队列、栈、图和网络的表示等数据结构,以及内存管理中的空闲块管理。 一、单链表 1....链表的第一个节点称为头节点,最后一个节点的指针域指向NULL,表示链表的结束。...常见应用 实现数据结构:如队列、栈等。 内存管理:如动态内存分配器的空闲块管理。 图和网络的表示:如邻接表表示法。 五、总结 链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。...六、结束语 本节内容已经全部介绍完毕,希望通过这篇文章,大家对C语言链表有了更深入的理解和认识。 感谢各位的阅读和支持,如果觉得这篇文章对你有帮助,请不要吝惜你的点赞和评论,这对我们非常重要。

    37710

    C语言函数的栈帧详解

    一、栈 简单来说栈的主要特点有: 一个限定表尾进行删除(出栈)和插入(入栈)操作的线性表,其过程类似与压子弹与退子弹(后进先出)。...EBP 存放栈底指针 汇编指令 用途 mov mov A,B 将数据B移动到A push 压栈 pop 出栈 call 函数调用 add 加法 sub 减法 rep 重复 lea 加载有效地址 三...引用百度百科:C语言中,每个栈帧对应着一个未运行完的函数。栈帧中保存了该函数的返回地址和局部变量。从这句话中,可以提炼以下几点信息: 栈帧是一块因函数运行而临时开辟的空间。...在函数栈帧、局部变量创建完毕后,进行Add()函数运算过程: PLAINTEXT c = a + b; 00AA13E5 mov eax,dword ptr [ebp+8] 00AA13E8...在函数拿到返回值后,开始出栈: PLAINTEXT 00AA13F1 pop edi 00AA13F2 pop esi 00AA13F3 pop

    2.2K20

    C语言括号匹配(栈括号匹配c语言)

    大家好,又见面了,我是你们的朋友全栈君。 给定一串字符,不超过100个字符,可能包括括号、数字、字母、标点符号、空格,编程检查这一串字符中的( ) ,[ ],{ }是否匹配。...如果遇到左括号,就入栈,如果遇到一个右括号,就与栈顶元素比较,如果匹配,出栈,就继续重复操作,直到字符串没有了。期间一旦出现不匹配的括号对就直接输出no ,如果栈空了,说明匹配了,就输出yes。...(char c)//判断是否为右括号,是返回1,否返回0. { if(c==')'||c=='}'||c==']') { return 1;...for(i=0;i的字符。 { if(left(s[i])==1)//如果是左括号入栈,同时栈顶向上移动。...{ if(check(stack[top-1],s[i]))//如果匹配,那么栈顶下移,继续执行下一次新的for循环。

    2.7K20

    洛谷 || 栈(C语言)

    题目背景 栈是计算机中经典的数据结构,简单的说,栈就是限制在一端进行插入删除操作的线性表。 栈有两种最重要的操作,即 pop(从栈顶弹出一个元素)和 push(将一个元素进栈)。...栈的重要性不言自明,任何一门数据结构的课程都会介绍栈。宁宁同学在复习栈的基本概念时,想到了一个书上没有讲过的问题,而他自己无法给出答案,所以需要你的帮忙。...题目描述 宁宁考虑的是这样一个问题:一个操作数序列1,2,…,n(图示为 1 到 3 的情况),栈 A 的深度大于n。...现在可以进行两种操作, 将一个数,从操作数序列的头端移到栈的头端(对应数据结构栈的 push 操作) 将一个数,从栈的头端移到输出序列的尾端(对应数据结构栈的 pop 操作) 使用这两种操作,由一个操作数序列就可以得到一系列的输出序列...(原始状态如上图所示) 你的程序将对给定的 n,计算并输出由操作数序列 1,2,…,n 经过操作可能得到的输出序列的总数。 输入格式 输入文件只含一个整数 n(1≤n≤18)。

    1.3K30

    合法的出栈序列

    poj 1363 Rails 已知从1至n的数字序列,按顺序入栈,每个数字入栈后即可出栈,也可在栈中 停留,等待后面的数字入栈出栈后,该数字再出栈,求该数字序列的某出栈 序列是否合法?...算法设计:使用栈与队列模拟入栈、出栈过程 同时使用一个队列与一个栈来解决该问题,设队列order与栈为S。队列order存储待判断是否合法 的出栈序列,使用栈S用来模拟出栈与入栈的过程。...1.按照1-n的顺序,将元素push进入栈S中: 2.每push一个元素,即检查栈顶S.top()是否与队列头部元素order.front()相同。...3.如果相同则同时弹出栈顶元素与队列头部元素,直到栈空或栈顶与队列头部元素不同。 若最终栈为空,则说明序列合法,否则不合法。...int n = order.size();//n为序列长度,将1-n按顺序入栈 for(int i = 1; 1<= n;i++){ s.push(i);//将i入栈

    1.1K20

    单调栈总结_进栈和出栈的算法思想

    单调栈是一种特殊的栈,特殊之处在于栈内的元素都保持一个单调性。...假设下图是一个栈内元素的排列情况(单调递增的栈): 此时插入情况有两种: (1).插入元素大于栈顶元素 当插入7时,因7 > 6,满足单调递增的条件,故可以直接加入栈 此时: (2...).插入的元素小于栈顶元素 当插入3时,为了满足单调递增栈的性质,需要先将栈顶的4,6弹出,再插入,此时: 功能 以上的内容和图我相信是非常容易理解的,但单调栈的作用和功能并不能得到很好的体现,故下面将用文字...7大于栈顶元素对应的元素3,故 L[3] = S.top() = 2 (栈顶元素的值) 然后将元素7对应的下标3存入栈 此时栈中情况: (4).i = 4时,为保持单调递增的性质,应将栈顶元素...总结:一个元素向左遍历的第一个比它小的数的位置就是将它插入单调栈时栈顶元素的值,若栈为空,则说明不存在这么一个数。

    32630

    栈(用C语言实现)

    栈 1.1 概念与结构 栈:⼀种特殊的线性表,其只允许在固定的⼀端进行插入和删除元素操作。进行数据插入和删除操作的⼀端称为栈顶,另⼀端称为栈底。...栈中的数据元素遵守后进先出 LIFO(Last In First Out)的原则。 压栈:栈的插⼊操作叫做进栈/压栈/入栈,入数据在栈顶。 出栈:栈的删除操作叫做出栈。出数据也在栈顶。...* ps, STDataType x); //出栈 void STPop(ST* ps); //取栈顶元素 STDataType STTop(ST* ps); //获取栈中有效元素个数 int...STSize(ST* ps); //栈是否为空 bool STEmpty(ST* ps); 实现栈的文件:Stack.c #include"Stack.h" void STInit(ST...arr[ps->top - 1]; } int STSize(ST* ps) {     assert(ps);     return ps->top; } 测试文件:text.c

    10110

    栈的介绍以及使用数组模拟栈的入栈和出栈

    栈(stack) 介绍 (1)栈是一个先进后出的有序列表 (2)栈是限制线性表中元素的插入和删除只能在线性表的同一端进行的一种特殊线性表。...(3)根据栈的定义可知,最先放入栈中的元素在栈底,最后放入的元素在栈顶,而删除元素时正好相反,最后放入的元素最先删除,最先放入的元素最后删除。...---- 使用数组模拟栈 思路分析 (1)定义一个 top 表示栈顶,初始化为 -1 (2)入栈的操作:stack[++top] = data; (3)出栈的操作:int value = stack[top...] = value; }  出栈 //出栈-pop,将栈顶的数据返回 public int pop() { //先判断栈是否为空 if(isEmpty(...int res = arrayStack.pop();//抛出异常 System.out.println("出栈的数据为

    21310

    全栈必备 :C语言基础

    在《全栈的技术栈设想》中埋下了4种编程语言的伏笔,已经兑现了Javacript,Python和Java, 本想将C/C++一并整理,但涉及面向对象等设计技术,最终还是C 梳理一下,从0到1吧。 ?...数据结构 C语言为用户提供了丰富的数据结构,还允许用户自定义复杂的数据结构。...C标准库有各种不同的实现,比如最著名的glibc, 用于嵌入式Linux的uClibc,还有ARM自己的C语言标准库等。...关于这部分代码对于开发者不可见,属于C标准运行时的一部分。 函数在调用和被调用过程中,都伴随着入栈和出栈,因此栈发挥着重要作用。函数的局部变量、参数、返回值都存在栈区中。...C语言被一些人誉为“上帝语言”,它几乎奠定了软件产业的基础,还创造了很多其它语言。但是,鉴于水平有限,难以举重若轻,本文中的基础描述只是老码农的碎碎念罢了。

    1.2K30
    领券