今天开始记录一下剑指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的更多相关文章

  1. 剑指Offer面试题:1.实现Singleton模式

    说来惭愧,自己在毕业之前就该好好看看<剑指Offer>这本书的,但是各种原因就是没看,也因此错过了很多机会,后悔莫及.但是后悔是没用的,现在趁还有余力,把这本书好好看一遍,并通过C#通通实 ...

  2. 剑指Offer面试题:14.链表的倒数第k个节点

    PS:这是一道出境率极高的题目,记得去年参加校园招聘时我看到了3次,但是每次写的都不完善. 一.题目:链表的倒数第k个节点 题目:输入一个链表,输出该链表中倒数第k个结点.为了符合大多数人的习惯,本题 ...

  3. 《剑指offer》面试题12:打印1到最大的n位数

    面试题12:打印1到最大的n位数 剑指offer题目12,题目如下 输入数字n,按顺序打印出1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的三位数999 方法一 和面试题11< ...

  4. 《剑指offer》面试题11: 数值的整数次方

    面试题11: 数值的整数次方 剑指offer面试题11,题目如下 实现函数double power(double base,int exponent),求base的exponent次方, 不得使用库 ...

  5. 剑指 Offer 题目汇总索引

    剑指 Offer 总目录:(共50道大题) 1. 赋值运算符函数(或应说复制拷贝函数问题) 2. 实现 Singleton 模式 (C#) 3.二维数组中的查找 4.替换空格              ...

  6. 面试题目——《剑指Offer》

    1.把一个字符串转换成整数——<剑指Offer>P29 2.求链表中的倒数第k个结点——<剑指Offer>P30 3.实现Singleton模式——<剑指Offer> ...

  7. 剑指offer习题集2

    1.把数组排成最小的数 class Solution { public: static bool compare(const string& s1, const string& s2) ...

  8. 剑指offer习题集1

    1.打印二叉树 程序很简单,但是其中犯了一个小错误,死活找不到,写代码要注意啊 这里左右子树,要注意是node->left,结果写成root->left vector<int> ...

  9. 剑指Offer:面试题20——顺时针打印矩阵(java实现)

    题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数 字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1, ...

  10. 牛客网上的剑指offer题目

    题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 题目:请实现一个函数,将一 ...

随机推荐

  1. Asp.Net Core 7 preview 4 重磅新特性--限流中间件

    前言 限流是应对流量暴增或某些用户恶意攻击等场景的重要手段之一,然而微软官方从未支持这一重要特性,AspNetCoreRateLimit这一第三方库限流库一般作为首选使用,然而其配置参数过于繁多,对使 ...

  2. python+pytest接口自动化(16)-接口自动化项目中日志的使用 (使用loguru模块)

    通过上篇文章日志管理模块loguru简介,我们已经知道了loguru日志记录模块的简单使用.在自动化测试项目中,一般都需要通过记录日志的方式来确定项目运行的状态及结果,以方便定位问题. 这篇文章我们使 ...

  3. 什么!Sentinel流控规则可以这样玩?

    项目源码地址:公众号回复 sentinel,即可免费获取源码 前言 上一篇文章中,我们讲解了关于sentinel基本介绍以及流控规则中直接和快速失败的效果,有兴趣的可以去看上一篇文章,今天,我们给大家 ...

  4. python并发编程之线程/协程

    python并发编程之线程/协程 part 4: 异步阻塞例子与生产者消费者模型 同步阻塞 调用函数必须等待结果\cpu没工作input sleep recv accept connect get 同 ...

  5. 使用docker搭建jupyter notebook / jupyterlab

    说明 由于官方镜像实在是不怎么好用,所以我自己做了一个优化过的jupyter notebook的镜像 notebook_hub,使用我这个镜像搭建容器非常简单,下面就基于这个notebook_hub来 ...

  6. 类型转换——JavaSE基础

    类型转换 类型判断 可以通过Instanceof关键字判断左操作数是否是右操作数的父类或本身 强制类型转换 不能对布尔值进行转换 不能将对象类型转换为不相关的类型 把高容量转向低容量时,需要进行强制类 ...

  7. Code Forces 1367A Sorting Parts 题解

    (原题链接:CF传送门) 题目背景(我看不懂英文嘤嘤嘤) Sorting Parts You have an array a of length n. You can exactly once sel ...

  8. Egg上层框架CabloyJS是如何输出SQL语句日志的?

    背景 在Egg开发实践中,经常会遇到一个问题:如何查看刚刚执行过的Egg组装的原生SQL语句呢? 1. 现有方案 可以直接在项目的config配置文件中添加MySQL配置debug: true.这会启 ...

  9. C# 将HTML转为XML

    本文以C#及VB.NET后端程序代码示例展示如何将HTML转为XML文件.转换时,调用Word API -Free Spire.Doc for .NET 提供的文档加载方法及文档保存的方法来实现.转换 ...

  10. python PIL 图片素描化

    from PIL import Image import numpy as np a = np.asarray(Image.open("D://7.jpg").convert('L ...