您的位置:首页 > 编程语言 > C语言/C++

用C语言实现在一个链表删除指定的一个或多个元素

2017-10-09 00:05 781 查看
#include<stdio.h>

#include<stdlib.h>

typedef struct node{
int data;
struct node *next;

}LinkList;
//创建一个链表 
LinkList *Creatlist_L(LinkList *L,int n){
LinkList *p,*h;
L=(LinkList*)malloc(sizeof(LinkList));
L->next=NULL;
h=L;
for(int i=0;i<n;i++){
p=(LinkList*)malloc(sizeof(LinkList));
scanf("%d",&p->data);
p->next=h->next;
h->next=p;
}
return L;
}
//删除指定的元素
LinkList *deletenode(LinkList *head,int m){
LinkList *p,*q,*s;
p=head;
q=head->next;
while(q){
if(q->data==m){
p->next=q->next;
s=q;
q=q->next;
free(s);

}else{
p=p->next;
q=q->next;
}
}
return head;

//输出链表 
void printlist(LinkList *head){
LinkList *p;
p=head->next;
if(!p){
printf("The link is NULL!");
exit(0);
}
while(p){
printf("%d",  p->data);
p=p->next;
}
}

  int main(){

  LinkList *head,*head1;

  int n=0,num=0;

  printf("请输入链表的长度:");

  scanf("%d",&n); 

 

  head=Creatlist_L(head,n);

  printf("链表创立成功!"); 

  printf("\n");

 

  printf("请输入要输入删除的元素:");


scanf("%d",&num);

  printf("\n");

 

  head=deletenode(head,num);

  printlist(head);

  }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐