数据结构--链表

Posted lu-007

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据结构--链表相关的知识,希望对你有一定的参考价值。

#include <iostream>
using namespace std;
typedef struct LNode
{
	int data;
	struct LNode * next;

}LNode, * Listlist;

//bool init(Listlist & L,int i) //尾插法
//{
//	LNode *new_node, *temp_node;
//	temp_node = L;
//	for (int num = 0; num < i; num++)
//	{
//		new_node = new LNode;
//		new_node->next = NULL;
//		cin >> new_node->data;
//		temp_node->next = new_node;
//		temp_node = new_node;
//	}
//}

bool init(Listlist & L, int i)    //头插法
{
	LNode * new_item, * temp_item;//申明一个暂时的节点的指针,然后一个向下传的界点的指针
	temp_item = L;//将这个临时的节点当成是一个乡下传递的一个指针
	int num;//数量
	for (num = 0; num < i; num++)
	{
		new_item = new LNode;//申明一个新的节点
		new_item->next = NULL;//将末尾置为空
		cin >> new_item->data;//输入这个新节点的值
		new_item->next = L->next;//将新节点指向第一个节点的地址
		L->next = new_item;//将头节点指向这个新的节点
	}
	return true;//返回正确
}

bool destroy(Listlist &L)
{
	Listlist temp;//临时的指针
	temp = L->next;//指向第一个节点
	while (temp)//判断这个节点是不是空的,并作为一个结束条件
	{
		L->next = L->next->next;//将头结点的下一个指针,指向下下个节点
		free(temp);//释放单独提出来的节点
		temp = L->next;//临时节点指向下一个节点
	}
	return true;//返回正确
}

bool listempty(Listlist L)
{
	return L->next ? false : true;//如果头指针的指向下一个节点的指针为空的话呢,那么这个就是一个空的链表.
}

int listlength(Listlist & L)
{
	Listlist temp;
	temp = L->next;//将头指针指向的一个节点,当做是第一个节点。
	int num = 1;//并赋值为1
	while (temp)//将temp作为一个判断是否为空的一个条件
	{
		temp = temp->next;//指向下一个,就像在数数一样
		num++;//数目加一
	}
	return num - 1;//因为最后一个数到的数是空指针所索引的数
}

bool getitem(Listlist L, int index, int &item)
{
	if (index < 1 && index>listlength(L))//先判断这个条件是不是成立的,符不符合我们的输入的条件
	{
		return false;//如果不符合,我们就返回这个错误的
	}
	LNode * temp;//申明的是一个临时节点的指针
	temp = L->next;//指向第一个节点
	int num = 1;//并且将这个节点的标号为1
	while (temp&&num < index - 1)//一个是将这个指针是不是空的作为一个判断条件,然后将这个是不是到了,这个后面当做是一个判断的条件
	{
		temp = temp->next;//将这个节点的值,指向下一个节点
		num++;//数目加一
	}
	if (!temp || num >= index - 1)
	{
		return false;
	}
	item = temp->data;
	return true;
}

bool locateitem(Listlist L, int index, int item)
{
	if (index<1 && index>listlength(L))
	{
		return false;
	}
	LNode * temp=L->next;
	int num = 1;
	while (temp&&num < index - 1)
	{
		temp = temp->next;
		num++;
	}
	return item == temp->data ? true : false;
}

bool listinsert(Listlist &L, int index, int item)
{
	if (index<1 && index>listlength(L))
	{
		return false;
	}
	LNode * temp=L;
	int num = 0;
	while (temp&&num < index - 1)
	{
		temp = temp->next;
		num++;
	}
	LNode * new_node = new LNode;
	new_node->next = temp->next;
	cin >> new_node->data;
	temp->next = new_node;
	return true;
}

bool deleteitem(Listlist & L, int index, int &item)
{
	if (index<1 && index>listlength(L))
	{
		return false;
	}
	LNode * temp=L;
	int num = 0;
	while (temp&&num < index - 1)
	{
		temp = temp->next;
		num++;
	}
	item = temp->next->data;
	temp->next = temp->next->next;
	return true;
}

  

以上是关于数据结构--链表的主要内容,如果未能解决你的问题,请参考以下文章

NC41 最长无重复子数组/NC133链表的奇偶重排/NC116把数字翻译成字符串/NC135 股票交易的最大收益/NC126换钱的最少货币数/NC45实现二叉树先序,中序和后序遍历(递归)(代码片段

JDK常用数据结构

817. Linked List Components - LeetCode

VSCode自定义代码片段5——HTML元素结构

VSCode自定义代码片段5——HTML元素结构

VSCode自定义代码片段5——HTML元素结构