2095.删除链表的中间节点

给你一个链表的头节点 head 。删除链表的中间节点 ,并返回修改后的链表的头节点 head

长度为 n 链表的中间节点是从头数起第 ⌊n / 2⌋ 个节点(下标从 0 开始),其中 ⌊x⌋ 表示小于或等于 x 的最大整数。

对于 n = 1、2、3、4 和 5 的情况,中间节点的下标分别是 0、1、1、2 和 2 。

示例 1:

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

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

解释:

上图表示给出的链表。节点的下标分别标注在每个节点的下方。

由于 n = 7 ,值为 7 的节点 3 是中间节点,用红色标注。

返回结果为移除节点后的新链表。

示例 2:

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

输出:[1,2,4]

解释:

上图表示给出的链表。

对于 n = 4 ,值为 3 的节点 2 是中间节点,用红色标注。

示例 3:

输入:head = [2,1]

输出:[2]

解释:

上图表示给出的链表。

对于 n = 2 ,值为 1 的节点 1 是中间节点,用红色标注。

值为 2 的节点 0 是移除节点 1 后剩下的唯一一个节点。

解题思路1

链表的删除

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* deleteMiddle(ListNode* head) {
        if (head->next == nullptr) {
            return nullptr;
        }

        int count = 0;
        ListNode* temp = head;
        while (temp != nullptr) { // 计算出链表的长度
            temp = temp->next;
            count++;
        }

        int mid = count / 2;
        cout<<mid<<endl;
        ListNode* p = head;
        for (int i = 0; i < mid; i++) {
            if (mid < 2) {
                // 如果中间位置小于2,说明只有两个元素,直接指向下一个元素的后一个即null
                head->next = head->next->next;
                break;
            }
            if (i == mid-1) {//移动到中间位置的前一个结点
               p->next=p->next->next;
            }
             p = p->next;//移动指针
        }
        return head;
    }
};
相关推荐
苏言の狗3 分钟前
小R的并集大小期望计算 | 蛮力
数据结构·算法
BineHello9 分钟前
MPC用优化求解器 - 解决无人机轨迹跟踪
算法·矩阵·自动驾驶·动态规划·无人机
橘颂TA11 分钟前
每日一练之链表的回文结构
数据结构·链表
誓约酱12 分钟前
(每日一题) 力扣 14 最长公共前缀
算法·leetcode·职场和发展
刃神太酷啦14 分钟前
数据结构(蓝桥杯常考点)
数据结构·c++·蓝桥杯c++组
冠位观测者1 小时前
【Leetcode 每日一题 - 补卡】2070. 每一个查询的最大美丽值
数据结构·算法·leetcode
誓约酱1 小时前
(每日一题) 力扣 860 柠檬水找零
linux·c语言·c++·算法·leetcode·职场和发展
地平线开发者1 小时前
手把手基于 MINI 数据集带你做一次板端精度评估
算法·自动驾驶
詹天佐1 小时前
ICCE 数字车钥匙介绍
人工智能·算法
ak啊1 小时前
记忆化(Memoization)
算法