用C語言實現在一個連結串列刪除指定的一個或多個元素
阿新 • • 發佈:2018-12-09
#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);
}
#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));
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);
}