您现在的位置是:首页 >技术交流 >【Leetcode -817.链表组件 -1019.链表中的下一个更大节点】网站首页技术交流

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

YoungMLet 2024-08-12 12:01:04
简介【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;
		}
风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。