数据结构每日一题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;
}
相关推荐
nice_lcj5201 小时前
数据结构之堆:从概念到应用全解析(附TOP-K经典问题)
java·数据结构·算法
漫随流水1 小时前
leetcode算法(429.N叉树的层序遍历)
数据结构·算法·leetcode·二叉树
漫随流水1 小时前
leetcode算法(116.填充每个节点的下一个右侧节点指针)
数据结构·算法·leetcode·二叉树
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——力扣 844 题:比较含退格的字符串
数据结构·c++·算法·力扣·结构与算法
自然数e3 小时前
c++多线程【多线程常见使用以及几个多线程数据结构实现】
数据结构·c++·算法·多线程
黛色正浓3 小时前
leetCode-热题100-普通数组合集(JavaScript)
java·数据结构·算法
千金裘换酒3 小时前
LeetCode 环形链表+升级版环形链表
算法·leetcode·链表
辞砚技术录3 小时前
MySQL面试题——索引、B+树
数据结构·数据库·b树·面试
666HZ6664 小时前
数据结构1.0 数据结构在学什么
数据结构·算法
余瑜鱼鱼鱼4 小时前
Java数据结构:从入门到精通(五)
数据结构