倒序思维~ (增删都在头部)一种 栈 思维

简介: 倒序思维~ (增删都在头部)一种 栈 思维

倒序思维~ (增删都在头部)一种 栈 思维


✿具体代码:

双端队列Deque可以作为栈的底层用子类双端链表 LinkedList 作为具体实现类,来实现栈的功能

②动态数组,  (想到动态数组,将数据插入到 下标为 0 的位置)

 

☺ 例子1: 动态数组:

//从叶子到根的遍历(层序遍历)~ 思路:倒序:只需要不断插入第一个位置
    public List<List<Integer>> levelOrderBottom(TreeNode root) {
        List<Integer> item = new ArrayList<>();
        List<List<Integer>> result = new ArrayList<>();
        if(root == null)     return result;
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        int levelSize = 1;
        while(!queue.isEmpty()) {
            TreeNode node = queue.poll();
            levelSize--;
            item.add(node.val);
            if(node.left != null) {
                queue.offer(node.left);
            }
            if(node.right != null) {
                queue.offer(node.right);
            }
            if(levelSize == 0) {
                result.add(0, item);
                item = new ArrayList<>();
                levelSize = queue.size();
            }
        }        
        return result;
    }

☺例子2:双端链表LinkedList:


//19_删除链表的倒数第N个结点
    // 通过栈(后进先出(pop掉 后面 第N个,从而可以拿到待删除结点的前一个结点))~  倒序思维~ 联想到数据结构栈
    class Solution2 {
        public ListNode removeNthFromEnd(ListNode head, int n) {
            ListNode dummy = new ListNode(0, head);
            Deque<ListNode> stack = new LinkedList<ListNode>();
            ListNode cur = dummy;
            while (cur != null) {
                stack.push(cur);
                cur = cur.next;
            }
            for (int i = 0; i < n; ++i) {
                stack.pop();
            }
            ListNode prev = stack.peek();
            prev.next = prev.next.next;
            ListNode ans = dummy.next;
            return ans;
        }
    }



目录
相关文章
|
5月前
数据结构堆排序中堆的建立、调整、插入、删除等操作的详解(题目讲解 简单易懂)
数据结构堆排序中堆的建立、调整、插入、删除等操作的详解(题目讲解 简单易懂)
222 0
|
4月前
每日一题 540. 有序数组中的单一元素
每日一题 540. 有序数组中的单一元素
|
11月前
|
存储 C语言
【数据结构】第八站:线性表的变化
【数据结构】第八站:线性表的变化
49 0
|
5月前
|
存储 Java
数据结构奇妙旅程之顺序表和链表
数据结构奇妙旅程之顺序表和链表
23..【摆脱list链表的束缚、让你爱上链表】(一)
23..【摆脱list链表的束缚、让你爱上链表】
34 0
竞赛:图解循环数组--借助循环数组进行队列的模拟实现以及循环数组的理解讲解
竞赛:图解循环数组--借助循环数组进行队列的模拟实现以及循环数组的理解讲解
竞赛:图解循环数组--借助循环数组进行队列的模拟实现以及循环数组的理解讲解
|
存储
【数据结构】顺序表和链表重点知识汇总(附有代码)
【数据结构】顺序表和链表重点知识汇总(附有代码)
|
Cloud Native Go
1441. 用栈操作构建数组:简单模拟+栈思想
这是 力扣上的 1441. 用栈操作构建数组,难度为 中等。
|
存储
全站最清晰的顺序队里实现讲解!数据结构之循环队列的实现
全站最清晰的顺序队里实现讲解!数据结构之循环队列的实现
48 0
数据结构练级之路【判断两条链表是否有交点】题目讲解
数据结构练级之路【判断两条链表是否有交点】题目讲解