有一个整数单链表L,涉及一个算法删除其中所有值为x的结点。

有一个整数单链表L,涉及一个算法删除其中所有值为x的结点。
输入格式:
第一行,直接给出相关的输入(整形),数据间英文字符的空格,最后回车结束输入。
第二行,给出要删除的数字(整形)。
输出格式:
输出整形结果,数据间一个英文空格隔开。
1.输入样例:
1 2 2 3 1
2
1.输出样例:
1 3 1
2.输入样例:
1 3 5 5 5 4 2 1 6 7 5 4 1
5
2.输出样例:
1 3 4 2 1 6 7 4 1

在成功构建单链表之后应该怎么做呢?

本人代码:
#include
#include
#define N 10
typedef int SLTDateType;
typedef struct Node
{
SLTDateType date;
struct Node *next;
}Node,*LinkList;
SLTDateType LinkList_Init(LinkList &L)
{
L=(LinkList)malloc(sizeof(Node));
if(L==NULL)
exit(-1);
L->next=NULL;
return 1;
}
void LinkList_createR(LinkList L,int n)
{
int i;
Node *p,*r;
r=L;
scanf("%d",n);
for(i=0;i
{
p=(LinkList)malloc(sizeof(Node));
scanf("%d",&p->date);
p->next=NULL;
r->next=p;
r=p;
}
}
void LinkList_print(LinkList L)
{
Node *p;
p=L->next;
while(p)
{
printf("%d ",p->date);
p=p->next;
}
printf("\n");
}

int main()
{
LinkList L;
int i;
int n=N;
LinkList_Init(L);
LinkList_createR(L,N);
printf("%d");
LinkList_print(L);
return 0;
}

你这个代码跟题目的要求不太符合,主要修改了一下LinkList_createR函数和main函数中的调用,运行结果:

img

代码修改如下:

#include<stdio.h>
#include<stdlib.h>
#define N 10
typedef int SLTDateType;
typedef struct Node
{
    SLTDateType date;
    struct Node *next;
}Node,*LinkList;
SLTDateType LinkList_Init(LinkList &L)
{
    L=(LinkList)malloc(sizeof(Node));
    if(L==NULL)
        exit(-1);
    L->next=NULL;
    return 1;
}
void LinkList_createR(LinkList L)  //,i)
{
    int x;
    char ch;
    Node *p,*r;
    r=L;

    while(1)
    {
        p=(LinkList)malloc(sizeof(Node));
        p->next = NULL;
        scanf("%d",&p->date);
        r->next = p; //p插入链表末尾
        r = p;
        ch = getchar();
        if(ch == '\n')
            break;
    }

    scanf("%d",&x);//读取x
    p = L;
    while(p->next)
    {
        if(p->next->date == x)
        {
            r = p->next;
            p->next = r->next;
            free(r);
        }else
            p = p->next;
    }
}
void LinkList_print(LinkList L)
{
    Node *p;
    p=L->next;
    while(p)
    {
        printf("%d ",p->date);
        p=p->next;
    }
    printf("\n");
}

int main()
{
    LinkList L;
    int i;
    int n=N;
    LinkList_Init(L);
    LinkList_createR(L);//,N);
    //printf("%d");
    LinkList_print(L);
    return 0;
}

只需要遍历链表,如果节点值为x,将前一个节点的next等于当前节点的next

void LinkList_Delete(LinkList L,int x)
{
   LinkList p = L,q;
   while(p->next != NULL)
   {
        if(p->next->date == x)
        {
            q = p->next;
            p->next = q->next;
            free(q);
        }
        else
            p = p->next;
   }
}

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632