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;
    }
};
相关推荐
九年义务漏网鲨鱼8 分钟前
【机器学习算法】面试中的ROC和AUC
算法·机器学习·面试
草莓熊Lotso9 分钟前
《算法闯关指南:优选算法--位运算》--38.消失的两个数字
服务器·c++·算法·1024程序员节
剪一朵云爱着6 小时前
力扣81. 搜索旋转排序数组 II
算法·leetcode·职场和发展
报错小能手8 小时前
刷题日常 5 二叉树最大深度
算法
ᐇ9599 小时前
Java LinkedList集合全面解析:双向链表的艺术与实战
java·开发语言·链表
码银9 小时前
【数据结构】顺序表
java·开发语言·数据结构
Greedy Alg9 小时前
LeetCode 84. 柱状图中最大的矩形(困难)
算法
im_AMBER9 小时前
Leetcode 52
笔记·学习·算法·leetcode
小欣加油9 小时前
leetcode 946 验证栈序列
c++·算法·leetcode·职场和发展