圆月山庄资源网 Design By www.vgjia.com
顺序表即线性表的顺序存储结构。它是通过一组地址连续的存储单元对线性表中的数据进行存储的,相邻的两个元素在物理位置上也是相邻的。比如,第1个元素是存储在线性表的起始位置LOC(1),那么第i个元素即是存储在LOC(1)+(i-1)*sizeof(ElemType)位置上,其中sizeof(ElemType)表示每一个元素所占的空间。
追加直接往列表后面添加元素,插入是将插入位置后的元素全部往后面移动一个位置,然后再将这个元素放到指定的位置,将长度加1删除是将该位置后面的元素往前移动,覆盖该元素,然后再将长度减1
实现代码:
#!/usr/bin/python # -*- coding: utf-8 -*- class SeqList(object): def __init__(self,maxsize): self.maxsize = maxsize self.data = range(maxsize) self.last = len(self.data) -1 def __getitem__(self, key): if self.is_empty(): print 'seqlist is empty' return elif key<0 or key>self.last: print 'the given key is Error' return else: return self.data[key] def __setitem__(self, key, value): if self.is_empty(): print 'seqlist is empty' return elif key<0 or key>self.last: print 'the given key is Error' return else: self.data[key] = value def __len__(self): length = self.last + 1 return length def getlength(self): return self.last+1 def clear(self): self.data = [] def is_empty(self): if self.last == -1: return True else: return False def is_full(self): if self.last == self.maxsize-1: return True else: return False def getelem(self,index): if self.is_empty(): print 'seqlist is empty' return elif index<0 or index>self.last: print 'position is error' else: return self.data[index] def getindex(self,elem): if self.is_empty(): print 'seqlst is empty' return else: for i in range(self.last): if self.data[i]==elem: return i def append(self,elem): if self.is_empty(): print 'seqlist is empty' return else: self.last +=1 self.data = self.data + [elem] def insert(self,index,elem): if self.is_empty(): print 'seqlist is empty' return elif index<0 or index> self.last+1: print 'postion is error' return elif index == self.last+1: self.last+=1 self.data = self.data + [elem] else: self.data += [elem] if index ==0: for i in self.data[self.last::-1]: self.data[i+1] = self.data[i] else: for i in self.data[self.last:index-1:-1]: self.data[i+1] = self.data[i] self.data[index] = elem self.last+=1 #print self.data def delete(self,index): if self.is_empty(): print 'seqlist is empty' return elif index<0 or index> self.last+1: print 'postion is error' return elif index == self.last+1: self.last -= 1 self.data =self.data[:-1] else: for i in self.data[:-1]: if i >= index: self.data[i] = self.data[i+1] else: pass self.data = self.data[:-1] self.last -= 1 sl = SeqList(5) print sl.data sl.append(5) print sl.data sl.insert(6,10) print sl.data sl.delete(5) print sl.data
说明:其实python中得list 本身是支持该种数据结构的,可以直接使用。
总结
以上就是本文关于Python数据结构之顺序表的实现代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:
python中实现k-means聚类算法详解
Python内存管理方式和垃圾回收算法解析
Python算法输出1-9数组形成的结果为100的所有运算式
如有不足之处,欢迎留言指出。
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年11月07日
2024年11月07日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]