链表基础操作——顺,逆序建立链表

本文详细介绍了如何使用C++实现顺序和逆序建立单链表,包括输入整数序列、创建链表节点、尾插法构建链表、遍历输出链表节点值。特别强调了在逆序建立链表时需要注意的指针处理问题,以避免逻辑错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Chapter 8, HLOJ 1989 顺序建立链表

输入一个整数n,再输入n个整数,按照输入的顺序建立单链表,并遍历所建立的单链表,输出这些数据。

输入格式:

测试数据有多组,处理到文件尾。每组测试输入一个整数n,再输入n个整数。

输出格式:

对于每组测试,输出顺序链表中的各结点的数据域的值(数据之间留一个空格)。

输入样例:

5 1 2 3 4 5

输出样例: 

1 2 3 4 5

思路分析:

创建链表,首先需要定义一个结构体Node,包含数据域data,与指针域next。

当我们输出输入都是用数据域,指针域的存在就是为了让我们实现冗长数据的插入删除等等操作。

比数组表现更为优秀。例如删除,数组需要把待删项的后面所有项全部前移一个长度,同时总长度减去1。

链表仅需把待删结点后一位链接到待删结点前一位就完成了,至于需不需要delete那个结点释放空间,完全

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值