✿具体代码:
①双端队列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;
}
}