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;
    }
};
相关推荐
Zhan8611242 小时前
数据接口的序列号机制与丢包检测:西班牙行情数据IBEX指数实时行情接入笔记
大数据·数据结构·笔记·区块链
菜鸡爱玩4 小时前
线性代数矩阵相乘
线性代数·算法·矩阵
devilnumber7 小时前
Java 递归算法 详解 + 核心要点 + 实战运用 + 避坑指南
java·开发语言·算法
‎ദ്ദിᵔ.˛.ᵔ₎9 小时前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾9 小时前
多头注意力机制
人工智能·深度学习·算法
H178535090969 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks
hujinyuan2016010 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
bIo7lyA8v10 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程11 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
退休倒计时11 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript