数据结构每日一题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;
}
相关推荐
Tairitsu_H4 小时前
C语言:排序(一)
c语言·数据结构·排序
j_xxx404_5 小时前
力扣题型--链表(两数相加|两两交换链表中的节点|重排链表)
数据结构·c++·算法·leetcode·蓝桥杯·排序算法
_日拱一卒6 小时前
LeetCode:240搜索二维矩阵Ⅱ
数据结构·线性代数·leetcode·矩阵
计算机安禾6 小时前
【数据结构与算法】第44篇:堆(Heap)的实现
c语言·开发语言·数据结构·c++·算法·排序算法·图论
汀、人工智能7 小时前
[特殊字符] 第91课:课程表
数据结构·算法·数据库架构·图论·bfs·课程表
测绘第一深情8 小时前
MapQR:自动驾驶在线矢量化高精地图构建的端到端 SOTA 方法
数据结构·人工智能·python·神经网络·算法·机器学习·自动驾驶
想带你从多云到转晴8 小时前
04、数据结构与算法---双向链表
java·数据结构·算法·链表
橘颂TA9 小时前
【笔试】算法的暴力美学——牛客 BC140:杨辉三角
数据结构·牛客
Lsk_Smion9 小时前
Hot100(开刷) 之 长度最小的数组--删除倒数第N个链表--层序遍历
java·数据结构·算法·kotlin
郝学胜-神的一滴10 小时前
从链表到二叉树:树形结构的入门与核心性质解析
数据结构·c++·python·算法·链表