数据结构课程设计报告:删除以L为头结点的单链表中值为k的所有结点并输出单链表长度__ 30

求源代码和使用的各种程序,求摘要... 求源代码和使用的各种程序,求摘要 展开
 我来答
语默_pinko
2016-06-13 · TA获得超过188个赞
知道小有建树答主
回答量:108
采纳率:0%
帮助的人:56.5万
展开全部
//删除以L为头结点的单链表中值为k的所有结点并输出单链表长度


#include "stdafx.h"
#include "stdio.h"
#include "malloc.h"

typedef struct lnode
{
int data;
lnode *next;
}node,*link;

void creatlink(link &L)
{
int a;
link p=L;
printf("输入链表的值:\n");
scanf("%d",&a);
while(a!=0)
{
p=(link)malloc(sizeof(node));
p->data=a;
p->next=L;
L=p;
scanf("%d",&a);
}
}



int length_delete(link &L,int k)
{
int count=1;
link p=L->next;
while(p)
{
if(p->data==k)
{
L->next=p->next;
free(p);
}
printf("%d ",L->data);
L=L->next;
p=L->next;
count++;
}
return count;
}


主函数:

//删除以L为头结点的单链表中值为k的所有结点并输出单链表长度


#include "stdafx.h"
#include "stdio.h"
#include "malloc.h"

typedef struct lnode
{
int data;
lnode *next;
}node,*link;

void creatlink(link &L)
{
int a;
link p=L;
printf("输入链表的值:\n");
scanf("%d",&a);
while(a!=0)
{
p=(link)malloc(sizeof(node));
p->data=a;
p->next=L;
L=p;
scanf("%d",&a);
}
}



int length_delete(link &L,int k)
{
int count=1;
link p=L->next;
while(p)
{
if(p->data==k)
{
L->next=p->next;
free(p);
}
printf("%d ",L->data);
L=L->next;
p=L->next;
count++;
}
return count;
}

刚刚现写的,希望能帮到你~:)

上海华然企业咨询
2024-10-28 广告
在测试大模型时,可以提出这样一个刁钻问题来评估其综合理解与推理能力:“假设上海华然企业咨询有限公司正计划进入一个全新的国际市场,但目标市场的文化习俗、法律法规及商业环境均与我们熟知的截然不同。请在不直接参考任何外部数据的情况下,构想一套初步... 点击进入详情页
本回答由上海华然企业咨询提供
丿艾瑞灬莉娅
2018-04-21 · TA获得超过916个赞
知道小有建树答主
回答量:926
采纳率:78%
帮助的人:432万
展开全部
#include <stdio.h>
#include <stdlib.h>

typedef int ElementType;    //    假设数据是int类型的(可以自己更改) 
typedef struct table
{
    ElementType data;
    struct table *next;
}List, Node;

void Error(const char *msg)
{
    printf("%s\n", msg);
    system("pause");
    exit(0);
}

int IsEmpty(const List *L)
{
    return L->next==NULL;
}

Node* CreateNode(ElementType X)                //    创建值为X的新的结点 
{
    Node *p = (List*) malloc(sizeof(*p));
    if(NULL == p)
        Error("No more memory!");
    p->data = X;
    p->next = NULL;    
    return p;
}

void Save(const ElementType X, List *L)        //    在链表末尾接入值为X的新结点 
{
    List *p = L;
    while(NULL != p->next)
        p = p->next;
    Node *newNode = CreateNode(X);
    p->next = newNode;
}

Node* FindPre(const ElementType X, List *L)    //    找到值为X的结点的前驱结点(删除操作需要) 
{
    List *p = L;
    while(NULL != p->next)
    {
        if(p->next->data == X)
            return p;    
        p = p->next;
    }
    return NULL;
}            
 
int GetListLength(const List *L)    //    获取链表长度 
{
    int length = 0;
    List *p = L->next;
    while(p != NULL)
    {
        ++length;
        p = p->next;
    }
    return length;
}

void Delete(const ElementType X, List *L)    //    删除链表中值为X的结点 
{
    int length = GetListLength(L);
    printf("Delete data %d\n", X);
    while(length--)
    {
        List *p = L;    
        Node *pre = FindPre(X, p);
        if(NULL == pre)
            break;
            
        Node *tmp = pre->next;
        pre->next = tmp->next;
        free(tmp);
    }
}

void PrintList(const List *L)        //    打印链表信息 
{
    if(IsEmpty(L))
        Error("Empty List!");
        
    List *p = L->next;
    while(p != NULL)
    {
        printf("%d ", p->data);
        p = p->next;
    }
    printf("\tList's length is %d\n", GetListLength(L));

 
int main()
{
    List *L1 = CreateNode(0);    //    创建头结点 
    
    int data[] = {1, 3, 5, 2, 3, 9, 0, 4, 3, 6};
    for(int i = 0; i < 10; i++)
        Save(data[i], L1);
    PrintList(L1);        
    Delete(3, L1);    
    PrintList(L1);
        
    return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
帐号已注销
2018-04-21 · TA获得超过2029个赞
知道小有建树答主
回答量:9715
采纳率:0%
帮助的人:1103万
展开全部
链表删除节点帮写代码 私信
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友1300f70
2017-03-08
知道答主
回答量:1
采纳率:0%
帮助的人:1025
展开全部
主函数
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式