栈练习--------从链表中移除节点(LeetCode 2487)

题目:LeetCode 2487

解法

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* removeNodes(ListNode* head) {
        vector<ListNode*> stk;
        ListNode* demmy = new ListNode(1000000,head);
        stk.push_back(demmy);
        while(head){
            while(stk.back()->val<head->val){
                stk.pop_back();
            }
            stk.push_back(head);
            head = head->next;
        }
        for(int i=0;i<stk.size()-1;i++){
            stk[i]->next = stk[i+1];
        }
        stk.back()->next=NULL;//这个不用写,最终数组的栈顶元素一定是初始链表的尾节点,一定指向NULL。
        return demmy->next;//应返回的是链表节点而非数组
    }
};

这个题目让我意识到了,vector不仅可以构建顺序表来实现栈,而且可以构建链表来实现栈,因为不论是栈、顺序表还是链表,他们本质上都是数组,所以本质就是利用vector来构建数组,然后利用数组来模拟栈。

这个题目思路是,首先构建一个链表,即数据类型为节点(结构体指针)的数组,然后定义一个虚拟头节点,特点是不会被移除,所以必须比题目给出的节点数据域都大,然后我们将这个demmy入栈,随后利用while循环遍历链表,在遍历过程中实现以下操作:

cpp 复制代码
while(stk.back()->val<head->val){
      stk.pop_back();
}
      stk.push_back(head);

在这几行语句中,我们要实现的操作是,将每一个节点传入栈中,但是在这之前,让待传入节点与栈顶元素作比较,如果大于栈顶元素,则弹出栈顶元素,重复判断和弹出操作,来实现对小节点的移除,最终栈就会变成一个单调不增的链表。

然后利用while循环,使这个链表串联起来,即让每个节点的next指针指向后者,最后一个节点指向NULL,(最后一个节点一定指向NULL,不用单独操作,最终数组的栈顶元素一定是初始链表的尾节点,一定指向NULL。)

相关推荐
dgaf13 分钟前
DX12 快速教程(17) —— 立体图标与合并渲染
c语言·c++·3d·图形渲染·d3d12
superior tigre1 小时前
78 子集
算法·leetcode·深度优先·回溯
一个爱编程的人3 小时前
一个数是不是素数
数据结构·算法
charlie1145141913 小时前
通用GUI编程技术——图形渲染实战(三十八)——顶点缓冲与输入布局:GPU的第一个三角形
开发语言·c++·学习·图形渲染·win32
superior tigre3 小时前
739 每日温度
算法·leetcode·职场和发展
用户805533698033 小时前
现代Qt开发教程(新手篇)1.10——进程
c++·qt
忡黑梨3 小时前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
海参崴-3 小时前
C++ STL篇 AVL树的模拟实现
开发语言·c++
汉克老师3 小时前
GESP2025年6月认证C++五级( 第二部分判断题(1-10))
c++·贪心算法·分治算法·线性筛法·gesp5级·gesp五级
6Hzlia3 小时前
【Hot 100 刷题计划】 LeetCode 15. 三数之和 | C++ 排序+双指针
c++·算法·leetcode