【Leetcode -817.链表组件 -1019.链表中的下一个更大节点】

简介: 【Leetcode -817.链表组件 -1019.链表中的下一个更大节点】

Leetcode -817.链表组件

题目:给定链表头结点 head,该链表上的每个结点都有一个 唯一的整型值 。同时给定列表 nums,该列表是上述链表中整型值的一个子集。

返回列表 nums 中组件的个数,这里对组件的定义为:链表中一段最长连续结点的值(该值必须在列表 nums 中)构成的集合。

示例 1:

输入: head = [0, 1, 2, 3], nums = [0, 1, 3]

输出 : 2

解释 : 链表中, 0 和 1 是相连接的,且 nums 中不包含 2,所以[0, 1] 是 nums 的一个组件,同理[3] 也是一个组件,故返回 2。

示例 2:

输入: head = [0, 1, 2, 3, 4], nums = [0, 3, 1, 4]

输出 : 2

解释 : 链表中,0 和 1 是相连接的,3 和 4 是相连接的,所以[0, 1] 和[3, 4] 是两个组件,故返回 2。

提示:

链表中节点数为n

1 <= n <= 10^4

0 <= Node.val < n

Node.val 中所有值 不同

1 <= nums.length <= n

0 <= nums[i] < n

nums 中所有值 不同

思路:用hash数组将 nums 数组中出现过的元素记录下来,然后遍历链表,如果可以组成 nums 数组的组件,就用 flag 标记为1,继续判断链表的下一个值是否是nums数组的组件,如果不是,就将上一个链表的组件 flag 统计到 ans 中,最后返回 ans ;如果是,就继续标记 flag 为1,一直迭代链表,直到空;如果一直迭代到空,flag 还是被标记为1,最后要处理这个1,把它统计到 ans 中;

int numComponents(struct ListNode* head, int* nums, int numsSize)
    {
        struct ListNode* cur = head;
        //hash数组记录nums中出现过的元素
        int hash[10000] = { 0 };
        int flag = 0, ans = 0;
        //将nums数组中出现过的元素在hash数组中标记为1
        for (int i = 0; i < numsSize; i++)
        {
            hash[nums[i]] = 1;
        }
        while (cur)
        {
            //如果链表中的元素有在nums数组中出现过,用flag记录;如果是相连的元素一直出现,那flag也一直等于1,一整串相当于出现一次
            if (hash[cur->val])
            {
                flag = 1;
            }
            //否则,或者一直出现的元素中断,用ans统计组件的个数;并将flag置0
            else
            {
                ans += flag;
                flag = 0;
            }
            //cur 迭代
            cur = cur->next;
        }
        //最后处理被遗漏的flag,因为如果链表中的元素一直连着组成组件,直到链表为空,那么这个组件还没算进 ans
        ans += flag;
        return ans;
    }

Leetcode -1019.链表中的下一个更大节点

题目:给定一个长度为 n 的链表 head

对于列表中的每个节点,查找下一个 更大节点 的值。也就是说,对于每个节点,找到它旁边的第一个节点的值,这个节点的值严格大于它的值。

返回一个整数数组 answer ,其中 answer[i] 是第 i 个节点(从1开始)的下一个更大的节点的值。

如果第 i 个节点没有下一个更大的节点,设置 answer[i] = 0

示例 1:

输入:head = [2, 1, 5]

输出:[5, 5, 0]

示例 2:

输入:head = [2, 7, 4, 3, 5]

输出:[7, 0, 5, 5, 0]

提示:

链表中节点数为 n

1 <= n <= 10^4

1 <= Node.val <= 10^9

思路:暴力方法,直接遍历链表,寻找下一个更大的节点,如果遍历到空,即没有下一个更大的节点,就将 0 放入返回的数组,否则就将这个更大的节点放入返回数组;

int* nextLargerNodes(struct ListNode* head, int* returnSize)
    {
        struct ListNode* cur = head, * ptr = head;
        //用len记录返回的长度,ret为返回的数组
        int len = 0;
        int* ret = (int*)malloc(sizeof(int) * 10000);
        while (ptr)
        {
            //cur每次从ptr开始遍历
            cur = ptr;
            //寻找当前比 ptr 下一个更大节点
            //cur的next不能为空,如果ptr的值大于等于cur的next的值,cur往后迭代
            while (cur->next && ptr->val >= cur->next->val)
                cur = cur->next;
            //如果没找到下一个更大的节点,将0放入返回数组
            if (cur->next == NULL)
                ret[len++] = 0;
            //如果找到,就将这个节点放入返回数组
            else if (ptr->val < cur->next->val)
                ret[len++] = cur->next->val;
            //每次找完 ptr 往后迭代
            ptr = ptr->next;
        }
        *returnSize = len;
        return ret;
    }
目录
相关文章
|
2月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
37 1
|
2月前
Leetcode第21题(合并两个有序链表)
这篇文章介绍了如何使用非递归和递归方法解决LeetCode第21题,即合并两个有序链表的问题。
51 0
Leetcode第21题(合并两个有序链表)
|
2月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
22 0
LeetCode第二十四题(两两交换链表中的节点)
|
2月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
44 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
2月前
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
52 0
|
2月前
【LeetCode 46】450.删除二叉搜索树的节点
【LeetCode 46】450.删除二叉搜索树的节点
19 0
|
2月前
|
索引
力扣(LeetCode)数据结构练习题(3)------链表
力扣(LeetCode)数据结构练习题(3)------链表
90 0
|
2月前
【LeetCode 10】142. 环形链表 II
【LeetCode 10】142. 环形链表 II
22 0
|
6月前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
6月前
|
存储 SQL 算法
LeetCode 题目 86:分隔链表
LeetCode 题目 86:分隔链表