栈练习--------从链表中移除节点(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。)

相关推荐
酉鬼女又兒4 分钟前
27. 移除元素
数据结构·算法·排序算法
划破黑暗的第一缕曙光8 分钟前
[C++]:1.C++基础
c++·c++基础
TracyCoder12314 分钟前
LeetCode Hot100(28/100)——104. 二叉树的最大深度
算法·leetcode
执着25925 分钟前
力扣hot100 - 101、对称二叉树
数据结构·算法·leetcode
三月微暖寻春笋28 分钟前
【和春笋一起学C++】(五十九)派生类和基类之间的关系
c++·基类·派生类·关系
数智工坊30 分钟前
【数据结构-栈、队列、数组】3.3栈在括号匹配-表达式求值上
java·开发语言·数据结构
阿猿收手吧!41 分钟前
【C++】inline变量:全局共享新利器
开发语言·c++
清风玉骨42 分钟前
特殊类的创建
c++
郝学胜-神的一滴44 分钟前
Python美学的三重奏:深入浅出列表、字典与生成器推导式
开发语言·网络·数据结构·windows·python·程序人生·算法
404未精通的狗1 小时前
(数据结构)排序
数据结构·排序算法