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;
    }
};
相关推荐
njidf9 小时前
C++中的访问者模式
开发语言·c++·算法
C_Si沉思9 小时前
C++中的工厂模式变体
开发语言·c++·算法
C羊驼10 小时前
C语言学习笔记(十五):预处理
c语言·经验分享·笔记·学习·算法
m0_5698814710 小时前
C++中的适配器模式变体
开发语言·c++·算法
励志的小陈10 小时前
数据结构---顺序表
数据结构
NAGNIP10 小时前
面试官:正则化都有哪些经典的方法?
算法·面试
Theodore_102210 小时前
深度学习(12)正则化线性回归中的偏差与方差调试
人工智能·深度学习·算法·机器学习·线性回归
m0_5698814711 小时前
跨语言调用C++接口
开发语言·c++·算法
老鼠只爱大米11 小时前
LeetCode经典算法面试题 #295:数据流的中位数(双堆法、有序列表、平衡树等多种实现方案详解)
算法·leetcode·优先队列··数据流·中位数·java 面试题
x_xbx11 小时前
LeetCode:215. 数组中的第K个最大元素
数据结构·算法·leetcode