【理解】链表的初始化与遍历

本文介绍了链表的初始化与遍历,重点讲解了初学链表的三个关键步骤,帮助读者深入理解链表的概念。通过学习,可以掌握动态分配内存空间的链表操作。
摘要由CSDN通过智能技术生成

点击目录传送ฅʕ•̫͡•ʔฅ

理解
我的链表

9.20 今天下午先到这( ̄▽ ̄)"

#include<iostream>
#include<cstdlib>
using namespace std;

//要敲出一个属于我的链表。。 
//需要头结点、头指针、结点的结构体、还有各种方法(一个一个的来)。 
typedef struct Node{
   
	//结点的结构体成员需要数据域和指针域
	char DF;		//数据域(用来存数据) 
	struct Node *next;	//这是一个指向结点的指针(指针域)
}LinkList;

//头结点
struct ListHead{
   
	//头结点的数据域可以用,可以不用,这里用来保存链表长度
	int Length;
	LinkList *next;		//头结点的指针域是指向首元结点的,也得是LinkList类型 
}; 

//还不能直接写方法,需要初始化链表。。。  
//初始化链表
LinkList * init(int *i){
   		//这是...结点指针类型的函数?
	//先安排上头指针 
	LinkList *Head,*p,*q;
	char ch;
	Head = q = NULL;
	cout << "Please enter the contents of the LinkList(End with enter):" << endl;
	while((ch = getchar()) != '\n'){
   	//每一次循环前getchar(输入)一个字符,判断是否为换行符(回车)。 
		//每一个字符都要存放在一个结点里
		p = (LinkList *)malloc(sizeof(LinkList));		//给新结点分配空间(可以把指向结点数据域首地址的指针看做结点)
		p->DF = ch;		//将接受的字符存到新建结点的数据域中
		if(!(*i)){
   		//这个i是头结点里存的链表长度的首地址(&Head->Length)这个(*i)是将长度取出,!(*i)的意思是如果长度不够。 
			Head = q = p;
			(*i)
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值