当前位置: 首页 > article >正文

链表Set_LinkList(建立)

用单链保存集合元素,元素由键盘输入。输入以-1结束,将所建链表打印输出。

链表结构如下图所示:

image.png

提示:

1.链表中数据元素为整型,typedef int ElemType;

2.用结构体自定义链表结构Set_LinkList ;

3.初始化链表函数init(),该函数可创建空链表L,返回L的头指针地址;

4.链表插入结点函数insert(Set_LinkList L, ElemType e),该函数可以向链表中插入集合元素e,注意集合元素不可重复;

5.链表打印输出函数display(Set_LinkList L),该函数可以遍历打印输出链表L;

6.主函数中需调用链表初始化函数init()创建空链表,用循环获取用户输入,输入数据为整数,输入以-1结束,之后将链表打印输出。

输入格式:

一组整数,以空格分隔,以-1结束

输出格式:

链表中所保存的集合数据(按照输入顺序)

输入样例:

在这里给出一组输入。例如:

9 4 0 7 1 5 6 9 8 7 9 6 5 4 1 2 3 6 5 -1

输出样例:

在这里给出相应的输出。例如:

9 4 0 7 1 5 6 8 2 3

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

栈限制

8192 KB

#include <bits/stdc++.h>
using namespace std;
typedef int ElemType;
struct node{
    ElemType Data;
    struct node* next;
};
typedef struct node* Set_LinkList;
Set_LinkList init(){
    Set_LinkList L = (Set_LinkList)malloc(sizeof(struct node));
    L->Data = -1;
    L->next = NULL;
    return L;
}
void insert(Set_LinkList L, ElemType e){
    Set_LinkList p = L->next;
    if(p == NULL){
        Set_LinkList newnode = (Set_LinkList)malloc(sizeof(struct node));
        L->next = newnode;
        newnode->Data = e;
        newnode->next = NULL;
        return;
    }
    while(p->next != NULL){
        if(p->Data == e){
            return;
        }
        p = p->next;
    }
    Set_LinkList newnode = (Set_LinkList)malloc(sizeof(struct node));
    p->next = newnode;
    newnode->Data = e;
    newnode->next = NULL;
}
void display(Set_LinkList L){
    Set_LinkList p = L->next;
    if(p == NULL){
        return;
    }
    while(p->next != NULL){
        cout<<p->Data<<' ';
        p = p->next;
    }
}
int main()
{
    int x = 0;
    Set_LinkList L = init();
    while(x != -1){
        cin>>x;
        insert(L , x);
    }
    display(L);
    return 0;
}

 


http://www.kler.cn/a/348821.html

相关文章:

  • UE5 圆周运动、贝塞尔曲线运动、贝塞尔曲线点
  • 查看系统服务
  • SpringBoot驱动的飘香水果购物网站:设计与实现
  • 单片机原理与技术
  • SpringBoot驱动的智能健康推荐系统
  • HTML 技巧
  • 线上问题复盘模板
  • 物联网年度“盛宴”!华普微受邀参加Silicon Labs Works With大会
  • OpenReview API | 高效检索会议论文
  • 快速理解http的get和post
  • 百果园利润暴跌收入下滑:加盟店减少88家,销售费用却大幅增长
  • MySQL事务、存储引擎
  • wifi配置文件在linux哪个目录上
  • leetcode栈与队列(一)-有效的括号
  • 12 项 ECMAScript 提案的最新进展!
  • 使用这款图片二维码生成器,快速将图片生成二维码
  • vue3--通用 popover 气泡卡片组件实现
  • RTSP推流服务搭建
  • sqli-labs less-18 http头user-agent注入
  • leetcode哈希表(二)-两个数组的交集