您现在的位置是:首页 >技术交流 >【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;
}