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;
    }
};
相关推荐
夏鹏今天学习了吗28 分钟前
【LeetCode热题100(47/100)】路径总和 III
算法·leetcode·职场和发展
smj2302_7968265233 分钟前
解决leetcode第3721题最长平衡子数组II
python·算法·leetcode
m0_626535201 小时前
力扣题目练习 换水问题
python·算法·leetcode
第六五1 小时前
DPC和DPC-KNN算法
人工智能·算法·机器学习
一匹电信狗1 小时前
【LeetCode_160】相交链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
Java技术实践1 小时前
JPA 用 List 入参在 @Query中报错 unexpected AST node: {vector}
数据结构·windows·list
陌路201 小时前
S4双向链表
数据结构·链表
再卷也是菜2 小时前
C++篇(14)二叉树进阶算法题
c++·算法
小邓儿◑.◑2 小时前
贪心算法 | 每周8题(三)
算法·贪心算法
2401_841495642 小时前
【数据结构】最长的最短路径的求解
java·数据结构·c++·python·算法·最短路径·图搜索