链表基础(含代码)

这两天把之前没搞懂的链表知识补上,以下是我刚开始学习如何创建链表的小总结(要进阶链表的大佬就没必要看了),只要按照这个步骤就能创建链表。

链表的优缺点和存储结构应该先搞明白,可以参考这里

觉得太简单可以直接跳过进行进一步深入学习的看这里 链表进阶

废话不多说,先上图进行步骤讲解,希望这样能够加深理解,结尾有完整代码

【1】定义一个节点结构 如定义一个人

//定义节点结构
class Person
{
public:
	string name;
	int age;
	Person *next;
};

【2】创建链表 尾插法

【2.1】先创建头节点head 一般不存储数据
在这里插入图片描述

【2.2】创建名为pre的辅助指针(也称当前指针) 初始化使其指向头节点
在这里插入图片描述

【2.3】创建新节点 如 n=5 则创建5个节点 但节点间没有关联

【2.3.1】先创建新节点newPerson
在这里插入图片描述

【2.3.2】输入新节点要保存的数据

		cin >> newPerson->name;
		cin >> newPerson->age;

【2.3.3】更新当前指针的next指向

在这里插入图片描述

【2.3.4】更新新节点的尾部指针指向

在这里插入图片描述

【2.3.5】更新当前指针pre的指向 即:当前指针指向新创建的节点

在这里插入图片描述
【2.3.6】返回头指针head

下面是代码

#include<iostream>
#include <string>

using namespace std;

//【1】定义节点结构
class Person
{
public:

	string name;
	int age;
	Person *next;
};

//【2】创建链表
Person *createList(int n)
{
	//【2.1】在堆区创建头节点
	Person *head = new Person;
	//【2.2】创建辅助指针
	Person *pre = head;

	//【2.3】循环创建新的节点
	for (int i = 1; i <= n; i++)
	{
		//【2.3.1】创建新的节点 此时还没有附任何数据
		Person *newPerson = new Person;
		
		//【2.3.2】给刚刚创建的新节点赋值
		cout << "请输入第" << i << "个人的名字和年龄:" << endl;
		cin >> newPerson->name;
		cin >> newPerson->age;
		
		//【2.3.3】连接链表
		pre->next = newPerson;
		
		//【2.3.4】更新尾部指针
		newPerson->next = NULL;
		
		//【2.3.5】更新辅助指针
		pre = newPerson;
	}
	
	//【2.3.6】返回头指针
	return head;
}

//打印链表 由于节点都是链在一起了,所以只要有头节点既可以遍历整个链表
void printList(Person *head)
{
	//指向新节点
	Person *p = head->next;
	while (p != NULL)
	{
		cout << p->name << " " << p->age << endl;
		p = p->next;
	}
}


int main()
{
	//节点数量为5
	int n = 5;
	//定义一个Person指针 来接收createList()函数在创建链表时返回的头地址
	Person *head = createList(n);
	printList(head);

	return 0;
}

看这里相信已经知道套路了,可以进行下一步了 链表进阶

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值