数据结构论坛

注册

 

发新话题 回复该主题

数据结构干货单链表的定义python和 [复制链接]

1#

#Python知识分享#

一、单链表的定义

1、单链表与顺序表不同,顺序表的每一个节点斗志存放数据元素,而单链表除了要存放数据元素外,还要存储将指向下一个节点的指针。

2、顺序表的优点是可以积极存取,存储数据元素的密度高;缺点是在存储时需要大量连续的空间,改变容量时不方便的。

3、单链表相比于顺序表而言,在存储时不要求大片连续的存储空间,在改变容量时比较方便;但是不可以随机存取,需要耗费一定的空格键来存放指针。

三、C代码定义一个单链表

structLNode//定义单链表节点的类型

{Intdata;//一个节点存放一个数据元素

structLNode*next;//next指针指向下一个节点

}

超实用性的Python零基础入门到进阶视频源码淘宝¥2购买已下架

存放数据元素的称为数据域;存放指针的称为指针域。

structLNode*p=(structLNode*)malloc(sizeof(structLNode));

在需要申请新的空间时,采用malloc函数来申请增加一个新节点,并采用指针p指向这个结点。

采用typedef关键字来对数据类型进行重命名,即通过取别名的方式,使得在使用时更加方便,不冗长,也能知道其所表示的含义。

typedef数据类型别名

typedefstructureLNodeLNode;

LNode*p=(LNode*)malloc(sizeof(LNode));

LNode*L;//声明一个指针指向单链表中第一个节点

或者LinkListL;(代码的可读性更强)

LNode*强调返回的是一个节点

LinkList强调的是一个单链表

代码定义单链表

typedefstructLNode{

intdata;

structLNode*next;

}LNode,*LinkList;

LNode*Getelem(LinkListL,inti){

intj=1;

LNode*p=L-next;

if(i==0)

returnL;

if(i1)

returnNULL;

while(p!=NULLji)

{p=p-next;

j++;}

returnp;}

Python代码定义存储数据的变量与指向下一个数据的变量/p>

data:数据

_next:下一个数据

def__init__(self,data,_next=None)/p>

self.data=data#存储数据元素的变量

self._next=_next#存储指向下一个数据元素的变量

def__repr__(self)/p>

returnstr(self.data)#定义节点的字节输出

本文系作者授权百家号发表,未经许可,不得转载。

分享 转发
TOP
发新话题 回复该主题