我们今天继续来看看周五留下的习题: 面试题:输入两个整数序列,第一个序列表示栈的压入顺序,请判断二个序列是否为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如:压入序列为{1,2,3,4,5},那{4,5,3,2,1} 就是该栈的弹出顺序,而{4,3,5,1,2} 明显就不符合要求: 这道题还是比较容易想到思路,很直观的想法就是建立一个辅助栈,把输入的第一个序列中的数字依次压入该辅助栈,并按照第二个序列的顺序依次从该栈中弹出数字. 提前想好测试用例 一样是老方法,我们先准备测试用例: 传入两个…
在<剑指Offer>中,在栈和队列习题中,作者留下来一道题目供读者自己实现,即"用两个队列实现一个栈". 在计算机数据结构中,栈的特点是后进先出,即最后被压入(push)栈的元素会第一个被弹出(pop);队列的特点是先进先出,即第一个进入队列的元素将会被第一个弹出来.虽然栈和队列特点是针锋相对,但是两者却相互联系,可以互相转换. 在"用两个队列实现一个栈"问题中,我们用两个队列的压入和弹出来模拟栈的压入和弹出.我们通过画图的手段把抽象的问题形象化. 在上…
题目: 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列.(注意:这两个序列的长度是相等的) 先上通过的代码: class Solution { public: bool IsPopOrder(vector<int> pushV,vector<int> popV) {…
面试 15:顺时针从外往里打印数字 题目:输入一个矩阵,按照从外向里以顺时针的顺序依次打印每一个数字.例如输入: {{1,2,3}, {4,5,6}, {7,8,9}} 则依次打印数字为 1.2.3.6.9.8.7.4.5 这是昨天最后给大家留下的题目,相信大家也有去思考如何处理这道题目了. 初看这个题目,比较容易理解,也无需牵扯到数据结构或者高级的算法,看起来问题比较简单,但实际上解决起来且并没有想象中的容易. 大家极有可能想到循环嵌套的方式,套用几个 for 循环就可以啦. 首先打印第 1…
题目描写叙述: 用两个栈实现一个队列. 队列的声明例如以下,请实现它的两个函数appendTail 和 deleteHead.分别完毕在队列尾部插入结点和在队列头部删除结点的功能. 解题思路: 栈的特性是后进先出,而队列的特性是先进先出. 因此,用两个栈来模拟队列的功能,在输入数据的时候,一次压入栈A.当要输出数据的时候,则将栈A的数据所有依次弹出,压入栈B . 这样.栈B 栈顶就是队列头元素.依次从栈B弹出,即队列的出队操作. 每次仅仅有当栈B 已经出栈全然了.才进行下一次的B栈入栈. 代码实…
// 面试题:用两个栈实现队列 // 题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail // 和deleteHead,分别完成在队列尾部插入结点和在队列头部删除结点的功能. #include <iostream> #include <stack> using namespace std; template <typename T> class CQueue//模板类,习惯就好了 { private: stack<T> sta…
题目 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 思路 栈1: 用于入队列存储 栈2: 出队列时将栈1的数据依次出栈,并入栈到栈2中 栈2出栈即栈1的底部数据即队列要出的数据. 注意: 栈2为空才能补充栈1的数据,否则会打乱当前的顺序. 代码 const stack1 = []; const stack2 = []; function push(node) { stack1.push(node); } function pop() { if(stack2…
c++里面stack,queue的pop都是没有返回值的, vector的pop_back()也没有返回值. 思路: 队列是先进先出 , 在stack2里逆序放置stack1的元素,然后stack2.pop() 但是当s1,s2都有元素时,应该优先s2.pop(),否则会报错,最好是各种模拟s1,s2的数据情况 不过说是用两个栈实现,但这里其实也是两个List # -*- coding:utf-8 -*- class Solution: def __init__(self): self.stac…
目录 16.反转链表 17.合并两个排序的链表 18.树的子结构…
题目:如下为类型CMyString的声明,请为该类型添加赋值运算符函数. class CMyString { public: CMyString(char* pData = NULL); CMyString(const CMyString & str); ~CMyString(void); private: char* m_pData; }; 分析: 赋值运算符要注意以下四点: 1.把返回值的类型声明为该类型的引用. 2.把传入的参数的类型声明为常量引用. 3.释放实例自身已有的内存. 4.判断…