算法通关:016:设计循环双端队列

文章目录

题目

leetcode641 设计循环双端队列

思路

代码

java 复制代码
import java.util.Deque;
import java.util.LinkedList;

/**
 * @Author: ggdpzhk
 * @CreateTime: 2024-08-03
 * 641 双端队列:利用双向链表和动态数组实现
 */
public class _016_DeQueue {

    /*提交时改名为MyCircularDeque1
    * 其实内部就是双向链表
    * 常数操作慢,但是leetcode数据量太小了,看不出劣势
    * */
    class MyCircularDeque1 {
        //LinkedList就是Java里面自带的双端队列
        public Deque<Integer> deque = new LinkedList<Integer>();
        public int size;//链表里面有几个数字
        public int limit;//限制双端列表里同时不能超过  的数字

        public MyCircularDeque1(int k) {
            size = 0;
            limit = k;
        }

        public boolean insertFront(int value) {
            if(isFull()){
                return false;
            }else{
                deque.offerFirst(value);
                size++;
                return true;
            }
        }

        public boolean insertLast(int value) {
            if (isFull()){
                return false;
            }else{
                deque.offerLast(value);
                size++;
                return true;
            }
        }

        public boolean deleteFront() {
            if(isEmpty()){
                return false;
            }else{
                deque.pollFirst();
                size--;
                return true;
            }
        }

        public boolean deleteLast() {
            if(isEmpty()){
                return false;
            }else{
                deque.pollLast();
                size--;
                return true;
            }
        }

        public int getFront() {
            if(isEmpty()){
                return -1;
            }
            return deque.peekFirst();
        }

        public int getRear() {
            if(isEmpty()){
                return -1;
            }
            return deque.peekLast();
        }

        public boolean isEmpty() {
            return size == 0;
        }

        public boolean isFull() {
            return size == limit;
        }
    }


    //用固定数组实现双端队列
    //主要就是处理边界问题
    class MyCircularDeque2 {

        public int[] deque;
        public int l,r,size,limit;//l,r表左右两个边界 []

        public MyCircularDeque2(int k) {
            deque = new int[k];
            size = 0;
            limit = k;
        }

        public boolean insertFront(int value) {
            if (isFull()){
                return false;
            }else{
                if(isEmpty()){
                    l = r = 0;
                    deque[0] = value;
                }else{
                    l = l == 0 ? (limit - 1) : (l - 1);
                    deque[l] = value;
                }
                size++;
                return true;
            }
        }

        public boolean insertLast(int value) {
            if (isFull()){
                return false;
            }else{
                if(isEmpty()){
                    l = r = 0;
                    deque[0] = value;
                }else{
                    r = r == limit - 1 ? 0 : r + 1;
                    deque[r] = value;
                }
                size++;
                return true;
            }
        }
        public boolean deleteFront() {
            if(isEmpty()){
                return false;
            }else{
                l = l == (limit-1) ? 0 : l + 1;
            }
            size--;
            return true;

        }
        public boolean deleteLast() {
            if(isEmpty()){
                return false;
            }else{
                r = r == 0 ? (limit - 1) : (r - 1);
            }
            size--;
            return true;
        }
        public int getFront() {
            if (isEmpty()){
                return -1;
            }
            return deque[l];
        }
        public int getRear() {
            if (isEmpty()){
                return -1;
            }
            return deque[r];
        }
        public boolean isEmpty() {
            return size == 0;
        }
        public boolean isFull() {
            return size == limit;
        }

    }
}

运行结果

问题

为什么能直接调用方法名

同一个类中的方法名能互相调用

  • 那改为if(deque.isFull())可以吗?
    可以,但是不好
相关推荐
JieE2123 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言