leetcode刷刷题(34) ---- 删除中间节点(C语言版)

2020-2-16
  • Listen to your inner voice.
    请聆听你内心的声音。
题目
实现一种算法,删除单向链表中间的某个节点(除了第一个和最后一个节点,不一定是中间节点),假定你只能访问该节点。

示例:
输入:单向链表a->b->c->d->e->f中的节点c
结果:不返回任何数据,但该链表变为a->b->d->e->f

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/delete-middle-node-lcci
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
个人解答:(C版本)
  • 刚开始思考的时候,有点懵,现在只知道要删除一个节点,单链表不知道该节点的上一个节点,是无法删除的。
  • 后来突然想到,我不一定要删掉这个节点,我把后一个节点的值赋值给该节点,然后删掉后面的节点,岂不是能达到一定的效果?
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
void deleteNode(struct ListNode* node) {
    struct ListNode* q = NULL;
    // 将下一个节点赋值给该节点
    node->val = node->next->val;
    q = node->next;
    // 删掉给出节点的下一个节点
    node->next = q->next;
	// 释放掉
    free(q);
}
  • 结果:
    在这里插入图片描述
他山之石:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值