【Leetcode -1721.交换链表中的节点 -2058.找出临界点之间的最小和最大距离】

简介: 【Leetcode -1721.交换链表中的节点 -2058.找出临界点之间的最小和最大距离】

Leetcode -1721.交换链表中的节点

题目:给你链表的头节点 head 和一个整数 k 。

交换 链表正数第 k 个节点和倒数第 k 个节点的值后,返回链表的头节点(链表 从 1 开始索引)。

示例 1:

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

输出:[1, 4, 3, 2, 5]

示例 2:

输入:head = [7, 9, 6, 6, 7, 8, 3, 0, 9, 5], k = 5

输出:[7, 9, 6, 6, 8, 7, 3, 0, 9, 5]

示例 3:

输入:head = [1], k = 1

输出:[1]

示例 4:

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

输出:[2, 1]

示例 5:

输入:head = [1, 2, 3], k = 2

输出:[1, 2, 3]

提示:

链表中节点的数目是 n

1 <= k <= n <= 105

0 <= Node.val <= 100

思路:找到需要交换的两个节点,交换它们的值即可;

struct ListNode* swapNodes(struct ListNode* head, int k)
    {
        //front为交换的两个节点的前一个节点,behind为交换的两个节点的后一个节点,cur用来让两个节点找到交换的两个位置
        struct ListNode* front = head, * behind = head, * cur = head;
        //front找到交换的第一个节点
        while (--k)
        {
            front = front->next;
            cur = cur->next;
        }
        //behind找到交换的第二个节点
        while (cur->next)
        {
            cur = cur->next;
            behind = behind->next;
        }
        //找到两个交换的节点之后,就对它们进行换值
        int num = front->val;
        front->val = behind->val;
        behind->val = num;
        return head;
    }

Leetcode -2058.找出临界点之间的最小和最大距离

题目:链表中的 临界点 定义为一个 局部极大值点 或 局部极小值点 。

如果当前节点的值 严格大于 前一个节点和后一个节点,那么这个节点就是一个 局部极大值点 。

如果当前节点的值 严格小于 前一个节点和后一个节点,那么这个节点就是一个 局部极小值点 。

注意:节点只有在同时存在前一个节点和后一个节点的情况下,才能成为一个 局部极大值点 / 极小值点 。

给你一个链表 head ,返回一个长度为 2 的数组[minDistance, maxDistance] ,其中 minDistance 是任意两个不同临界点之间的最小距离,maxDistance 是任意两个不同临界点之间的最大距离。如果临界点少于两个,则返回[-1, - 1] 。

示例 1:

输入:head = [3, 1]

输出:[-1, -1]

解释:链表[3, 1] 中不存在临界点。

示例 2:

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

输出:[1, 3]

解释:存在三个临界点:

  • [5, 3, 1, 2, 5, 1, 2]:第三个节点是一个局部极小值点,因为 1 比 3 和 2 小。
  • [5, 3, 1, 2, 5, 1, 2]:第五个节点是一个局部极大值点,因为 5 比 2 和 1 大。
  • [5, 3, 1, 2, 5, 1, 2]:第六个节点是一个局部极小值点,因为 1 比 5 和 2 小。
    第五个节点和第六个节点之间距离最小。minDistance = 6 - 5 = 1 。
    第三个节点和第六个节点之间距离最大。maxDistance = 6 - 3 = 3 。

示例 3:

输入:head = [1, 3, 2, 2, 3, 2, 2, 2, 7]

输出:[3, 3]

解释:存在两个临界点:

  • [1, 3, 2, 2, 3, 2, 2, 2, 7]:第二个节点是一个局部极大值点,因为 3 比 1 和 2 大。
  • [1, 3, 2, 2, 3, 2, 2, 2, 7]:第五个节点是一个局部极大值点,因为 3 比 2 和 2 大。
    最小和最大距离都存在于第二个节点和第五个节点之间。
    因此,minDistance 和 maxDistance 是 5 - 2 = 3 。
    注意,最后一个节点不算一个局部极大值点,因为它之后就没有节点了。

示例 4:

输入:head = [2, 3, 3, 2]

输出:[-1, -1]

解释:链表[2, 3, 3, 2] 中不存在临界点。

提示:

链表中节点的数量在范围[2, 105] 内

1 <= Node.val <= 105

思路:遍历链表,找到链表中所有的临界点,放入提前创建好的数组中;然后判断临界点的数量是否大于2,如果小于2,即返回的数组中的最小距离和最大距离都是 -1 ;如果大于2,最大距离即是数组中的最后一个减去第一个,即最大减最小;最小距离需要遍历数组,找到相邻的元素中差值最小的值;

int* nodesBetweenCriticalPoints(struct ListNode* head, int* returnSize)
    {
        struct ListNode* cur = head;
        //minDistance为最小距离,maxDistance为最大距离,index记录下标
        int minDistance = -1, maxDistance = -1, index = 1;
        //返回两个整型
        int* ret = (int*)malloc(sizeof(int) * 2);
        *returnSize = 2;
        //数组存放临界点的下标,len记录当前数组的长度
        int arr[100000] = { 0 };
        int len = 0;
        //每次比较前一个的val和后一个val,若符合题意就放入数组
        while (cur->next && cur->next->next)
        {
            int x = cur->val;
            cur = cur->next;
            index++;
            if (cur->val > x && cur->val > cur->next->val)
                arr[len++] = index;
            else if (cur->val < x&& cur->val < cur->next->val)
                arr[len++] = index;
        }
        //len,数组长度大于1,据题意,即临界点要大于两个
        if (len > 1)
        {
            //上面len多加了一次,所以要减一次
            len--;
            //maxDistance即为最大减最小
            maxDistance = abs(arr[len] - arr[0]);
            //minDistance要遍历一次数组,找出相邻之间最小的值
            for (int i = 1; i <= len; i++)
            {
                if (i == 1)
                    minDistance = arr[i] - arr[i - 1];
                minDistance = minDistance > arr[i] - arr[i - 1] ? arr[i] - arr[i - 1] : minDistance;
            }
        }
        ret[0] = minDistance;
        ret[1] = maxDistance;
        return ret;
    }
目录
相关文章
|
3月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
46 1
|
3月前
Leetcode第21题(合并两个有序链表)
这篇文章介绍了如何使用非递归和递归方法解决LeetCode第21题,即合并两个有序链表的问题。
60 0
Leetcode第21题(合并两个有序链表)
|
3月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
34 0
LeetCode第二十四题(两两交换链表中的节点)
|
3月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
50 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
3月前
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
61 0
|
3月前
【LeetCode 46】450.删除二叉搜索树的节点
【LeetCode 46】450.删除二叉搜索树的节点
29 0
|
3月前
|
索引
力扣(LeetCode)数据结构练习题(3)------链表
力扣(LeetCode)数据结构练习题(3)------链表
112 0
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
5月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
69 6
|
5月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
137 2