数据结构每日一题day13(链表)★★★★★

题目描述:采用尾插法在头指针L处建立一个带头结点的单链表,输入-1表示结束结果返回建立的单链表。

算法思想:

1.初始化链表:创建一个头结点(不存储实际数据),头指针 L 指向该头结点。初始时,头结点的 next 指针为 NULL,尾指针 tail 也指向头结点。

2.循环输入数据:从用户输入中读取数据,直到输入 -1 为止。

对于每个非 -1 的数据,创建一个新节点,并将数据存入新节点的数据域。

将新节点插入到尾节点之后(即 tail->next = newNode)。

更新尾指针,使其指向新节点(即 tail = newNode)。

3.结束处理:输入 -1 后,将尾节点的 next 指针置为 NULL,表示链表结束。

4.返回链表:返回头指针 L,即建立的单链表。

复杂度分析:

时间复杂度:O(n)

空间复杂度:O(n)

代码实现:

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

// 定义单链表结点结构
typedef struct LNode {
    int data;           // 数据域
    struct LNode *next; // 指针域
} LNode, *LinkList;

// 尾插法创建单链表
LinkList CreateList_Tail() {
    LinkList L = (LinkList)malloc(sizeof(LNode)); // 创建头结点
    L->next = NULL;                              // 头结点的next初始化为NULL
    LNode *tail = L;                             // 尾指针初始指向头结点
    int x;

    printf("请输入链表元素(以-1结束):\n");
    scanf("%d", &x);
    while (x != -1) {
        LNode *p = (LNode *)malloc(sizeof(LNode)); // 创建新结点
        p->data = x;                               // 赋值
        p->next = NULL;                            // 新结点的next为NULL
        tail->next = p;                            // 尾结点的next指向新结点
        tail = p;                                  // 更新尾指针
        scanf("%d", &x);
    }

    return L; // 返回头结点
}

// 打印单链表
void PrintList(LinkList L) {
    LNode *p = L->next; // 跳过头结点
    printf("链表元素:");
    while (p != NULL) {
        printf("%d ", p->data);
        p = p->next;
    }
    printf("\n");
}

int main() {
    LinkList L = CreateList_Tail(); // 创建链表
    PrintList(L);                   // 打印链表
    return 0;
}
相关推荐
爱吃KFC的大肥羊2 小时前
C/C++常用字符串函数
c语言·数据结构·c++·算法
武文斌773 小时前
嵌入式——数据结构:基础知识和链表①
数据结构
神器阿龙4 小时前
排序算法-冒泡排序
数据结构·算法·排序算法
九章数学体系5 小时前
九章数学体系:打破“吃苦悖论”,重构学习真谛
数据结构·学习·算法·数学建模·拓扑学
一川月白7095 小时前
数据结构---概念、数据与数据之间的关系(逻辑结构、物理结构)、基本功能、数据结构内容、单向链表(该奶奶、对象、应用)
c语言·数据结构·算法·哈希算法·单向链表·数据关系
闪电麦坤956 小时前
数据结构:链表(Linked List)
数据结构·链表
东东最爱敲键盘8 小时前
数据结构: 双向链表
数据结构
云泽80817 小时前
数据结构前篇 - 深入解析数据结构之复杂度
c语言·开发语言·数据结构
逝雪Yuki17 小时前
数据结构与算法——字典(前缀)树的实现
数据结构·c++·字典树·前缀树·左程云
技术思考者17 小时前
Leetcode - 反转字符串
数据结构·算法·leetcode