算法通关: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())可以吗?
    可以,但是不好
相关推荐
.YM.Z44 分钟前
【数据结构】:排序(一)
数据结构·算法·排序算法
Chat_zhanggong3451 小时前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
百***48071 小时前
【Golang】slice切片
开发语言·算法·golang
墨染点香1 小时前
LeetCode 刷题【172. 阶乘后的零】
算法·leetcode·职场和发展
做怪小疯子1 小时前
LeetCode 热题 100——链表——反转链表
算法·leetcode·链表
做怪小疯子3 小时前
LeetCode 热题 100——矩阵——旋转图像
算法·leetcode·矩阵
努力学习的小廉3 小时前
我爱学算法之—— BFS之最短路径问题
算法·宽度优先
高山上有一只小老虎4 小时前
构造A+B
java·算法
木头左4 小时前
缺失值插补策略比较线性回归vs.相邻填充在LSTM输入层的性能差异分析
算法·线性回归·lstm
sin_hielo4 小时前
leetcode 2435
数据结构·算法·leetcode