C++ 数据结构算法 学习笔记(4)-链表续

本文详细介绍了C++中单链表的遍历、获取元素、查找元素、删除元素以及链表销毁的代码示例,包括防御性编程和内存管理技巧。
摘要由CSDN通过智能技术生成

C++ 数据结构算法 学习笔记(4)-链表 续

单链表的遍历

代码例子:

void Link_print(LinkList*& L)
{
	LinkNode* p = NULL;
	if (!L)
	{
		cout << "This list is NULL!" << endl;
		return;
	}
	p = L->next;

	while (p)
	{
		cout << p->data<<" ";
		p = p->next;
	}
}

单链表获取元素

代码例子:

bool Link_GetElem(LinkList*& L, int i, int& e)	//Single List get element
{
	int index;
	LinkList* p;

	if (!L || !L->next)	return false;
	p = L->next;
	index = 1;

	while (p && index < i) //list scanned to behind, until the p pointing to the i element or p is NULL
	{
		p = p->next; //p pointing to the next node
		index++;
	}

	if (!p || index>i )
	{
		return false;
	}

	e = p->data;
	return true;
}

这个代码的底层逻辑是循环while (p && index < i)会将p指针指向该元素,然后再直接取指针的值.

其中,也有写上防御性编程, 比如当客户输入i值为负数的时候,while循环将不会执行,这样使得程序会进入下一个if判断(原因是 index>i). 然后程序将返回false

另外,如果用户输入要取元素的值大过链表的大小时,程序也会返回false. 原因是p将会是NULL,然后程序会进入if判断输出false

单链表查找元素

代码例子:

bool Link_FindElem(LinkList* L, int& index, int e)
{
	LinkList* p;
	p = L->next;
	index = 1;
	if (!L || !L->next)
	{
		index = 0;
		return false;
	}
    
	while (p && p->data != e)
	{
		p = p->next;
		index++;
	}

	if (!p)
	{
		index = 0;
		return false;
	}

	return true;
}

这个代码的实现逻辑是while循环会一直寻找元素为 e的链表.

具体实现为当第一个节点的元素不是e的话,会进入while循环里使得指针p指向下一个节点,直到指到元素为e的节点时会退出循环,然后由于index是引用所以会直接把main函数里定义的index值修改.

由于index的值不可能为0, 所以当程序没找到e的值的话会把index返回为0

单链表删除元素

代码例子:

bool LinkDelete(LinkList*& L, int i)
{
	LinkList* p, * q;
	int index = 0;
	p = L;

	if (!L || !L->next)
	{
		return false;
	}
	while ((p->next) && (index < i - 1))
	{
		p = p->next;
		index++;
	}
	if ((!p->next) || (index > i - 1))   //When i>n or i<1, delete position is not valid
	{
		return false;
	}
	q = p->next; 
	p->next = q->next;
	delete q;
}

代码的实现逻辑为, 当用户想要删除第二个节点的时候,此时我们需要让一个指针指向第一个节点.

这个原因是一旦我们让指针指向第一个节点的时候我们才可以直接修改第一个节点的指针域以便让它指向原本第三的节点.

这样的话我们才可以直接删除掉第二个节点.

另外,我们一定要记得加上代码delete q以便不会有内存泄漏的问题发生

单链表销毁

代码例子:

void LinkDestroy(LinkList*& L)
{
	//define a temporary node p to poiting to the head node
	LinkList* p = L;
	cout << "Delete the entire list" << endl;

	while (p)
	{
		L = L->next;
		cout << "Deleting the list" << endl;
		delete p;
		p = L;
	}
}

这个代码的实现逻辑是让一个指针pwhile里面循环,若p!=NULL的话就会删除掉该p 当然我们需要另一个指针L 以便当我们删掉p内存是还能将p 赋值到下一个节点的地址L

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值