剑指offer(13)-栈的压入、弹出序列 九度1366
题目来自剑指offer系列 九度 1366:http://ac.jobdu.com/problem.php?pid=1367
- 题目描述:
- 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。
- 输入:
- 每个测试案例包括3行:第一行为1个整数n(1<=n<=100000),表示序列的长度。第二行包含n个整数,表示栈的压入顺序。第三行包含n个整数,表示栈的弹出顺序。
- 输出:
- 对应每个测试案例,如果第二个序列是第一个序列的弹出序列输出Yes,否则输出No。
- 样例输入:
-
5
1 2 3 4 5
4 5 3 2 1
5
1 2 3 4 5
4 3 5 1 2
- 样例输出:
-
Yes
No
看到这个题太熟悉了,数据结构考试中会经常遇到。使用栈模拟一编即可。这里为了效率直接用数组模拟栈了。
//============================================================================
// Name : 栈的序列判断.cpp
// Author : coder
// Version :
// Copyright : www.acmerblog.com
// Description : Hello World in C++, Ansi-style
//============================================================================
#include <iostream>
#include <stdio.h>
using namespace std;
const int M=100001;
int n,stack[M],arr1[M];
char buf[M*10];
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
for(k=0; k<n; k++){
scanf("%d", &tmp);
//如果栈为空,或栈的顶端元素 不等于 要出栈的, 就一直入栈
while( top==0 || tmp != stack[top-1] ){
stack[top++] = arr1[cnt++];
if(cnt>=n) break;
}
top--; //出栈
if(cnt>=n) break;
}
k++;
//所有元素已入栈,则出栈顺序唯一
bool flag = true;
for(; k<n; k++){
scanf("%d", &tmp);
if( tmp != stack[--top]){
flag = false; break;
}
}
gets(buf);//读取剩下多余的
printf("%s\n", flag ? "Yes":"No");
}
return 0;
}
/**************************************************************
Problem: 1366
User: 从此醉
Language: C++
Result: Accepted
Time:140 ms
Memory:3276 kb
****************************************************************/
123
fdsfsdf
1
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
2
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
3
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
12
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
13
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
23
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
123]
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
-------------------
1
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
2
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
12
int main() {
while(~scanf("%d", &n)){
int top=0; //栈的顶端位置
int cnt=0; //已入栈的个数
int i, k, tmp;
for(i=0; i<n; i++)
scanf("%d", &arr1[i]);
剑指offer(13)-栈的压入、弹出序列 九度1366的更多相关文章
- 【剑指offer】栈的压入弹出序列,C++实现(举例)
原创文章,转载请注明出处! 本题牛客网地址 博客文章索引地址 博客文章中代码的github地址 1.题目 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为第一个序列的出栈序列.注意 ...
- 剑指offer-面试题31-栈的压入弹出序列-栈
#include<iostream> #include<string.h> #include<algorithm> #include<cmath> #i ...
- 剑指Offer:栈的压入、弹出序列【31】
剑指Offer:栈的压入.弹出序列[31] 题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈 ...
- 剑指 Offer 31. 栈的压入、弹出序列 + 入栈顺序和出栈顺序的匹配问题
剑指 Offer 31. 栈的压入.弹出序列 Offer_31 题目详情: 解析: 这里需要使用一个栈来模仿入栈操作. package com.walegarrett.offer; /** * @Au ...
- 剑指 Offer 31. 栈的压入、弹出序列
剑指 Offer 31. 栈的压入.弹出序列 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如,序列 {1,2,3,4,5} 是某 ...
- 【剑指Offer】栈的压入、弹出队列 解题报告(Python)
[剑指Offer]栈的压入.弹出队列 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-interviews ...
- Go语言实现:【剑指offer】栈的压入、弹出序列
该题目来源于牛客网<剑指offer>专题. 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5 ...
- 剑指Offer 21. 栈的压入、弹出序列 (栈)
题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压 ...
- 剑指OFFER之栈的压入、弹出序列(九度OJ1366)
题目描述: 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈 ...
随机推荐
- 基于Prometheus搭建SpringCloud全方位立体监控体系
前提 最近公司在联合运维做一套全方位监控的系统,应用集群的技术栈是SpringCloud体系.虽然本人没有参与具体基础架构的研发,但是从应用引入的包和一些资料的查阅大致推算出具体的实现方案,这里做一次 ...
- js 终止 forEach 循环
1.因为 forEach() 无法通过正常流程终止,所以可以通过抛出异常的方式实现终止. try{ var array = ["first","second", ...
- 学会使用简单的MySQL操作
第十八章 学会使用简单的MySQL操作 在前面两个章节中已经介绍过MySQL的安装了.可是光会安装还不够.还须要会一些主要的相关操作.当然了,关于MySQL的内容也是非常多的.仅仅只是对于linux系 ...
- 【DB2】NULLS LAST与NULLS FIRST
DB2函数配合 select row_number() over(order by col desc nulls first/nulls last ) as rn,col from table1ord ...
- Hibernate继承类的实现
版权声明:本文为博主原创文章,如需转载请标注转载地址. 博客地址:http://www.cnblogs.com/caoyc/p/5603724.html 对于继承关系类的映射.比如在论坛中文章(Ar ...
- Springmvc UPDATE 数据时 ORA-01858:a non-numeric character was found where a numeric was expected
ORA-01858:a non-numeric character was found where a numeric was expected 异常. 我的代码: 主要是绑定变量带出来的问题. 出错 ...
- (七)Oracle学习笔记—— 游标
1.游标简介 游标用来处理从数据库中检索的多行记录(使用SELECT语句).利用游标,程序可以逐个地处理和遍历一次检索返回的整个记录集. 为了处理SQL语句,Oracle将在内存中分配一个区域,这就是 ...
- myBatis的引出
jdbc 优点:简单易学,上手快,非常灵活构建sql,效率高. l缺点:代码繁琐,难以写出高质量的代码(资源的释放,SQL注入安全性等),开发者关注多,又要写业务逻辑,又要关注对象的创建和销毁. Hi ...
- jquery easyUi columns日期格式化
jquery easyUi columns日期格式化 方法一 Date.prototype.format = function (format) { var o = { "M+" ...
- How to fix Cannot change version of project facet Dynamic Web Module to 3.0 Error in Eclipse---转载
How to fix Cannot change version of project facet Dynamic Web Module to 3.0 Error in Eclipse 原文:http ...