昨日一题 1670. 设计前中后队列(中等,列表)

news2024/11/28 4:27:40

在这里插入图片描述

  1. 维护左右两个队列,控制左队列的长度比右队列长,且不超过1
  2. pushFront 往左队列的左边添加元素
  3. pushMiddle 往左队列的右边或者右队列的左边添加元素
  4. 其余同理,可以参照代码
class FrontMiddleBackQueue:

    def __init__(self):
        self.llist, self.rlist = [], []

    def pushFront(self, val: int) -> None:
        self.llist.insert(0, val)
        if len(self.llist) > len(self.rlist) + 1:
            self.rlist.insert(0, self.llist.pop())

    def pushMiddle(self, val: int) -> None:
        if len(self.llist) > len(self.rlist):
            self.rlist.insert(0, self.llist.pop())
        self.llist.append(val)

    def pushBack(self, val: int) -> None:
        self.rlist.append(val)
        if len(self.rlist) > len(self.llist):
            self.llist.append(self.rlist.pop(0))

    def popFront(self) -> int:
        if len(self.llist) == 0:
            return -1
        ans = self.llist.pop(0)
        if len(self.rlist) > len(self.llist):
            self.llist.append(self.rlist.pop(0))
        return ans

    def popMiddle(self) -> int:
        if len(self.llist) == 0:
            return -1
        ans = self.llist.pop()
        if len(self.rlist) > len(self.llist):
            self.llist.append(self.rlist.pop(0))
        return ans

    def popBack(self) -> int:
        if len(self.llist) == 0:
            return -1
        if len(self.rlist) == 0:
            return self.llist.pop()
        ans = self.rlist.pop()
        if len(self.llist) > len(self.rlist) + 1:
            self.rlist.insert(0, self.llist.pop())
        return ans

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1266827.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

博客RESTful API 接口开发

目录 1.博客系统规划 2.基础服务搭建 3.登录接口 4.新增文章接口 5.查询文章接口 6.修改文章接口 7.删除文章接口 总结 1.博客系统规划 首先规划一下有哪些接口,从博客文章角度来看,需要如下接口: 新增文章接口,传递…

Windows下搭建Tomcat HTTP服务,发布公网远程访问

文章目录 前言1.本地Tomcat网页搭建1.1 Tomcat安装1.2 配置环境变量1.3 环境配置1.4 Tomcat运行测试1.5 Cpolar安装和注册 2.本地网页发布2.1.Cpolar云端设置2.2 Cpolar本地设置 3.公网访问测试4.结语 前言 Tomcat作为一个轻量级的服务器,不仅名字很有趣&#xff0…

第二证券:五日线是什么颜色的线?

从概念解说上来看,五日线是一种短期移动平均线,通常使用股票五日收盘价的平均值进行核算,然后描绘出股票短线的走势趋势。在技能图上,五日线通常以赤色或蓝色表示,不同的平台能够设定不同的色彩。 在实践应用过程中&a…

海康运行管理中心 RCE漏洞复现

0x01 产品简介 海康威视是以视频为核心的智能物联网解决方案和大数据服务提供商。海康运行管理中心是一款功能强大、易于使用的安防管理平台,能满足用户对视频监控、报警管理、设备配置和数据统计等方面的需求,帮助用户建立高效、智能的安防系统。 0x02…

前端算法专栏-数组-75.颜色分类

介绍 Hi 大家好。我是程序员库里,今天新开一个前端算法专栏。 接下来会分类给大家分享常考算法题目。 很多朋友也是看着这套系列算法拿到很多offer!所以也是想分享给更多朋友,帮助到有需要的朋友。 分类 数组-三路快排 题目 75. 颜色分…

20-多线程

20.1线程简介 世间有很多工作都是可以同时完成的。例如,人体可以同时进行呼吸、血液循环、思考问题等活用户既可以使用计算机听歌,也可以使用它打印文件。同样,计算机完全可以将多种活动同时进这种思想放在 Java 中被称为并发,而…

JAVA基础进阶(八)

一、Map的体系结构 单列集合的顶层接口是Collection接口,双列集合的顶层接口是Map接口。 双列集合的元素是成对出现的,每一个元素称之为一个键值对。 二、Map系列集合的特点 Map系列集合的特点有以下几点: 键不能重复、值可以重复每一个元素都是一个键值对HashMa…

Xilinx Zynq-7000系列FPGA多路视频处理:图像缩放+视频拼接显示,提供工程源码和技术支持

目录 1、前言免责声明 2、相关方案推荐FPGA图像处理方案FPGA图像缩放方案FPGA视频拼接叠加融合方案推荐 3、设计思路详解HLS 图像缩放介绍Video Mixer介绍 4、vivado工程介绍PL 端 FPGA 逻辑设计PS 端 SDK 软件设计 5、工程移植说明vivado版本不一致处理FPGA型号不一致处理其他…

【C++ Primer Plus学习记录】do while循环

do while循环是出口条件循环。这意味着这种循环将首先执行循环体,然后再判定测试表达式,决定是否应继续执行循环。如果条件为false,则循环终止;否则,进入新一轮的执行和测试。这样的循环通常至少执行一次,因…

Element的安装与基本使用

文章目录 一.什么是Element?二.Element的安装(Vscode)三.在Vue项目中引入ElementUI组件库四.编写Element的Vue组件文件五.演示如何使用Element官网中的组件根组件中引入Element组件内容进行网页展示 一.什么是Element? Element是饿了么团队研发的一套为开发者与设计师等准备…

Unity工具脚本-检测资源文件夹是否有预制件是指定层级

效果: 先在菜单栏里面找到Tools/CheckPrefabLayers打开窗口 代码: using System.Collections; using System.Collections.Generic; using System.IO; using UnityEditor; using UnityEngine;public class CheckPrefabLayers : EditorWindow {public in…

典型的SAST支持检测标准

这里我们列举了Coverity、Cobot、代码卫士、Klocwork、QAC、C test几款典型的SAST工具,看看他们都是支持那些C、C标准(主要是C、C标准,其它语言较少)呢? 这可以作为厂商研发的方向标。 (结束)

好物分享(领劵优惠好手)

本次分享一个领取领优惠、充值、会员、购物优惠等功能 部分截图 需要的点击下方按钮 前往体验 感谢大家的支持 更多内容请关注微信小程序,源码、插件、模板及时更新

Breadcrumb面包屑(antd-design组件库)简单用法和自定义分隔符

1.Breadcrumb面包屑 显示当前页面在系统层级结构中的位置,并能向上返回。 2.何时使用 当系统拥有超过两级以上的层级结构时; 当需要告知用户『你在哪里』时; 当需要向上导航的功能时。 组件代码来自: 面包屑 Breadcrumb - Ant Des…

【功能测试】软件系统测试报告

1.引言 1.1.目的 本测试报告为 xxx 系统测试报告,本报告目的在于总结测试阶段的测试及测试结果分析,描述系统是否达到需求的目的。 本报告预期参考人员包括测试人员、测试部门经理、开发人员、项目管理人员等。 1.2.参考文档 《xxxx系统需求规格说明…

【MATLAB】RLMD分解+FFT+HHT组合算法

有意向获取代码,请转文末观看代码获取方式~也可转原文链接获取~ 1 基本定义 RLMD分解FFTHHT组合算法是一种强大的分析方法,结合了局部均值分解(LMD)、快速傅里叶变换(FFT)和希尔伯特-黄变换(H…

第二证券:机构密集调研消费电子、半导体产业链

据上海证券报记者核算,近一个月来,共有41家消费电子类公司和92家半导体公司(核算标准:申万职业2021,下同)发布出资者调研纪要。其间,有的公司款待了16个批次估计超200家安排,更有公司…

P8A009-A011活动目录安全

设置目录数据库访问权限 【预备知识】 活动目录(Active Directory)是面向Windows Standard Server、Windows Enterprise Server以及 Windows Datacenter Server的目录服务。(Active Directory不能运行在Windows Web Server上,但…

SpringBoot : ch10 整合Elasticsearch

前言 欢迎阅读本文,本文将介绍如何在Spring Boot应用程序中整合Elasticsearch。随着信息量的不断增加,对数据的高效管理和检索变得尤为重要。Elasticsearch作为一个强大的开源搜索和分析引擎,为我们提供了一个灵活且高效的解决方案。 在本文…

sqli-labs靶场详解(less1-less10)

目录 less-1 less-2 less 3 less 4 less 5 less-6 less-7 less-8 less-9 less-10 1-10关代码分析 less-1 判断注入点 ?id1 正常 ?id1 报错:to use near 1 ?id1\ 报错:to use near 1\ ?id1 and 11 正常 ?id1 and 11 报错:to …