剑指offer——day-1
今天开始记录一下剑指offer的题目训练,提升一下自己的编程能力吧
题目一:
用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )
示例 1:
输入:
["CQueue","appendTail","deleteHead","deleteHead"]
[[],[3],[],[]]
输出:[null,null,3,-1]
示例 2:
输入:
["CQueue","deleteHead","appendTail","appendTail","deleteHead","deleteHead"]
[[],[],[5],[2],[],[]]
输出:[null,-1,null,null,5,2]
大致讲下我的思路吧,其实是比较简单的一道栈的题目。使用两个栈,因为明确规定了只能用栈操作,所以只使用数据的pop和push方法,对栈顶进行增删。
栈1用来根据 append 函数的传参对数据进行push操作,将数据一个一个压到栈1,
栈2是将栈1 使用pop方法,将栈1 的最新数据一个一个压到栈2。
这样子,我们就根据数据进来的顺序和倒序分别存储到了一个栈1和栈2
根据题目实现的操作就是先进先出,但是因为栈只能先进后出,所以创建一个新栈储存先进来的数据,再将其弹出,就实现了先进先出
举例,数据进来的顺序 1,2,3,5,6,栈1的储存结构(push储存):(栈顶)6,5,3,2,1(栈底)
栈2的储存结构(栈1 pop出去再push到栈1):(栈顶)1,2,3,5,6(栈底)
代码如下
var CQueue = function() {
this.stack1=[],
this.stack2=[]
};
/**
* @param {number} value
* @return {void}
*/
CQueue.prototype.appendTail = function(value) {
this.stack1.push(value)
};
/**
* @return {number}
*/
CQueue.prototype.deleteHead = function() {
if(this.stack2.length){
return this.stack2.pop();
}else{
while(this.stack1.length){
this.stack2.push(this.stack1.pop());
}
if(!this.stack2.length){
return -1;
}else{
return this.stack2.pop();
}
}
};
题目二:
定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中,调用 min、push 及 pop 的时间复杂度都是 O(1)。
示例:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.min(); --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.min(); --> 返回 -2.
这题个人感觉,知道思路之后会比题目一好写
大概讲下我的思路:同样使用两个栈,
栈 1 只负责push进来储存数据
栈 2 只存储最小值,栈 1 push一个数值,栈 2 就根据栈 2 的栈顶判断跟栈 1 push的值哪个比较小,栈 2 栈顶值小,就push该栈顶值,如果栈 1 的push值比栈 2 栈顶值小,则栈 2 push栈 1 所push的值
难以理解,举例如下:
一:栈 1 :1,2,3,4,5
栈 2 :1,1,1,1,1
二:栈 1 :0,0,-1,2,-3
栈 2 :0,0,-1,-1,-3
三:栈 1 :-1,-2,4,0,-5
栈 2 :-1,-2,-2,-2,-5
当栈1弹出时,栈2也弹出,取栈一的最小值实际就是取栈2 的栈顶值
代码如下
ar MinStack = function() {
this.stake=[]
this.mins=[]
this.minValue=0
};
/**
* @param {number} x
* @return {void}
*/
MinStack.prototype.push = function(x) {
this.stake.push(x)
if(this.mins.length==0){
this.mins.push(x)
this.minValue=x
}else{
if(this.minValue<x){
this.mins.push(this.minValue)
}else{
this.minValue=x
this.mins.push(this.minValue)
}
}
};
/**
* @return {void}
*/
MinStack.prototype.pop = function() {
this.mins.pop()
this.minValue= this.mins[this.mins.length-1]
return this.stake.pop()
};
/**
* @return {number}
*/
MinStack.prototype.top = function() {
return this.stake[this.stake.length-1]
};
/**
* @return {number}
*/
MinStack.prototype.min = function() {
return this.mins[this.mins.length-1]
剑指offer——day-1的更多相关文章
- 剑指Offer面试题:1.实现Singleton模式
说来惭愧,自己在毕业之前就该好好看看<剑指Offer>这本书的,但是各种原因就是没看,也因此错过了很多机会,后悔莫及.但是后悔是没用的,现在趁还有余力,把这本书好好看一遍,并通过C#通通实 ...
- 剑指Offer面试题:14.链表的倒数第k个节点
PS:这是一道出境率极高的题目,记得去年参加校园招聘时我看到了3次,但是每次写的都不完善. 一.题目:链表的倒数第k个节点 题目:输入一个链表,输出该链表中倒数第k个结点.为了符合大多数人的习惯,本题 ...
- 《剑指offer》面试题12:打印1到最大的n位数
面试题12:打印1到最大的n位数 剑指offer题目12,题目如下 输入数字n,按顺序打印出1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的三位数999 方法一 和面试题11< ...
- 《剑指offer》面试题11: 数值的整数次方
面试题11: 数值的整数次方 剑指offer面试题11,题目如下 实现函数double power(double base,int exponent),求base的exponent次方, 不得使用库 ...
- 剑指 Offer 题目汇总索引
剑指 Offer 总目录:(共50道大题) 1. 赋值运算符函数(或应说复制拷贝函数问题) 2. 实现 Singleton 模式 (C#) 3.二维数组中的查找 4.替换空格 ...
- 面试题目——《剑指Offer》
1.把一个字符串转换成整数——<剑指Offer>P29 2.求链表中的倒数第k个结点——<剑指Offer>P30 3.实现Singleton模式——<剑指Offer> ...
- 剑指offer习题集2
1.把数组排成最小的数 class Solution { public: static bool compare(const string& s1, const string& s2) ...
- 剑指offer习题集1
1.打印二叉树 程序很简单,但是其中犯了一个小错误,死活找不到,写代码要注意啊 这里左右子树,要注意是node->left,结果写成root->left vector<int> ...
- 剑指Offer:面试题20——顺时针打印矩阵(java实现)
题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数 字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1, ...
- 牛客网上的剑指offer题目
题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 题目:请实现一个函数,将一 ...
随机推荐
- 1903021121—刘明伟—Java第四周作业—java分支语句学习
项目 内容 课程班级博客链接 19信计班(本) 作业要求链接 第四周作业 要求 每道题要有题目,代码(使用插入代码,不会插入代码的自己查资料解决,不要直接截图代码!!),截图(只截运行结果). 扩展阅 ...
- 《Mybatis 手撸专栏》第8章:把反射用到出神入化
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 为什么,读不懂框架源码? 我们都知道作为一个程序员,如果想学习到更深层次的技术,就需 ...
- 119_Power Pivot 长尾明细显示为【其他】
博客:www.jiaopengzi.com 焦棚子的文章目录 请点击下载附件 一.背景 最近比较忙,太久不没有更新文章,确实没有好的素材,就写一个吧. 在关于产品数据分析的时候,我们经常关注的是主要的 ...
- 什么!Sentinel流控规则可以这样玩?
项目源码地址:公众号回复 sentinel,即可免费获取源码 前言 上一篇文章中,我们讲解了关于sentinel基本介绍以及流控规则中直接和快速失败的效果,有兴趣的可以去看上一篇文章,今天,我们给大家 ...
- 企业应用架构研究系列二十六:信号量SemaphoreSlim与Semaphore
在进行多线程程序的开发和设计的过程中,不可避免的需要引入semaphore信号量这个组件,这是.net框架提供的一个对多线程计数互斥的方案,就是允许指定的线程个数访问特定的资源而增加的 一个" ...
- Random方法中的nextInt(int arg0)方法讲解
nextInt方法会生成一个随机的在5以内的数,负载均衡随机策略底层用的就是这个方法: Random rand = new Random(); int index = rand.nextInt(5); ...
- CYaRon!语
P3695 CYaRon!语 开始之前 上次水了些小模拟之后感觉不能再颓废了,于是就来大模拟. 然后这个题花了我一个多星期 还是最差解 不过,为了纪念我的第 20 道紫题,纪念我这一周的努力,我还是想 ...
- Vuex的各个模块封装
一.各个模块的作用: state 用来数据共享数据存储 mutation 用来注册改变数据状态(同步) getters 用来对共享数据进行过滤并计数操作 action 解决异步改变共享数据(异步) 二 ...
- WPF开发随笔收录-唯一标识符GUID
一.前言 该系列博客用于记录本人在WPF开发过程中遇到的各种知识点 二.正文 1.在工作的项目中,软件需要用到在线升级功能,由于第一次弄,在下载服务端的文件到本地时,文件的名称我选择直接生成为固定的格 ...
- Spring Boot:整合Swagger
1.先创建一个SpringBoot项目 其中application.properties文件中是创建项目时自动添加的配置. 2.添加相关maven依赖 <!--swagger--> < ...