请教数据结构C语言代码,删除以L为头节点的单链表中值为K的第一个结点

请教数据结构C语言代码,删除以L为头节点的单链表中值为K的第一个结点的程序代码... 请教数据结构C语言代码,删除以L为头节点的单链表中值为K的第一个结点的程序代码 展开
 我来答
风若远去何人留
2017-03-22 · 知道合伙人互联网行家
风若远去何人留
知道合伙人互联网行家
采纳数:20412 获赞数:450127
专业C/C++软件开发

向TA提问 私信TA
展开全部

假定链表节点定义为

typedef struct node
{
    int v;
    struct node *next;
}Node, *List;

那么函数可以写作

void del_node(List L, int k)
{
    Node *p,*q;
    p=L;
    q=L->next;
    while(q)
    {
        if(q->v==k)
        {
            p->next = q->next;
            free(q);
            q=p->next;
        }
        else 
        {
            p=q;
            q=p->next;
        }
    }
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式