码迷,mamicode.com
首页 > 其他好文 > 详细

带表头链表结点的删除

时间:2018-08-05 11:03:35      阅读:147      评论:0      收藏:0      [点我收藏+]

标签:head   pac   link   else   free   scanf   printf   style   带表头   

#include <stdio.h>

#include <stdlib.h>

#define N 9

typedef struct node

{

int data;

    struct node *next;

}ElemSN;

ElemSN *Createlink(int a[],int n){

int i;

    ElemSN *h,*p;

    h=p=(ElemSN*)malloc(sizeof(ElemSN));

    h->next=NULL;

    for(i=0;i<N;i++){

       p=p->next=(ElemSN*)malloc(sizeof(ElemSN));

       p->data=a[i];

       p->next=NULL;

    }

return h;

}

void DelkeyNode(ElemSN*h,int key){

ElemSN *p,*delp;

        for(p=h;p->next&&p->next->data-key;p=p->next);

       if(!p->next)

   printf("Not found!\n");

        else {

      delp=p->next;

              p->next=delp->next;

      free(delp);

      delp=NULL;

}

}

void Printlink(ElemSN *h){

ElemSN *p;

        for(p=h;p->next;p=p->next)

        printf("%2d\n",p->next->data);

}

int main(void){

    int a[N]={1,2,3,4,5,6,7,8,9};

    int key;

    ElemSN *head;

    head=Createlink(a,9);

    printf("key=");

    scanf("%d",&key);

    DelkeyNode(head,key);

    Printlink(head);

}


带表头链表结点的删除

标签:head   pac   link   else   free   scanf   printf   style   带表头   

原文地址:http://blog.51cto.com/13645380/2154832

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!