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

#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);
  }

猜你喜欢

转载自blog.csdn.net/new_buff_007/article/details/78178671