m0_68396682 2022-10-27 19:57 采纳率: 88.9%
浏览 333
已结题

有一个整数单链表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<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,int n)
{
int i;
Node *p,*r;
r=L;
scanf("%d",n);
for(i=0;i<n;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;
}

  • 写回答

4条回答 默认 最新

  • 关注

    你这个代码跟题目的要求不太符合,主要修改了一下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;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 11月4日
  • 已采纳回答 10月27日
  • 创建了问题 10月27日

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效