顺序表即线性表的顺序存储结构。它是通过一组地址连续的存储单元对线性表中的数据进行存储的,相邻的两个元素在物理位置上也是相邻的。比如,第1个元素是存储在线性表的起始位置LOC(1),那么第i个元素即是存储在LOC(1)+(i-1)*sizeof(ElemType)位置上,其中sizeof(ElemType)表示每一个元素所占的空间。
下面是顺序表的python实现:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
#coding:utf-8
'''
author:xzfreewind
'''
class SeqList( object ):
def __init__( self , max = 10 ):
self . max = max #默认顺序表最多容纳10个元素
#初始化顺序表数组
self .num = 0
self .date = [ None ] * self . max
def is_empty( self ): #判定线性表是否为空
return self .num is 0
def is_full( self ): #判定线性表是否全满
return self .num is self . max
#获取线性表种某一位置的元素
def __getitem__( self , i):
if not isinstance (i, int ): #如果i不为int型,则判定输入有误,即Type错误
raise TypeError
if 0 < = i < self .num: #如果位置i满足条件,即在元素个数的范围内,则返回相对应的元素值,否则,超出索引,返回IndexError
return self .date[i]
else :
raise IndexError
#修改线性表种某一位置的元素
def __setitem__( self , key, value):
if not isinstance (key, int ): #如果key不为int型,则判定输入有误,即Type错误
raise TypeError
if 0 < = key < self .num: #如果位置key满足条件,即在元素个数的范围内,则返回相对应的元素值,否则,超出索引,返回IndexError
self .date[key] = value
else :
raise IndexError
#按值查找元素的位置
def getLoc( self ,value):
n = 0
for j in range ( self .num):
if self .date[j] = = value:
return j
if j = = self .num:
return - 1 #如果遍历顺序表还未找到value值相同的元素,则返回-1表示顺序表种没有value值的元素
#统计线性表中元素的个数
def Count( self ):
return self .num
#表末尾插入操作
def appendLast( self ,value):
if self .num > = self . max :
print 'The list is full'
return
else :
self .date[ self .num] = value
self .num + = 1
#表任意位置插入操作:
def insert( self ,i,value):
if not isinstance (i, int ):
raise TypeError
if i < 0 and i > self .num:
raise IndexError
for j in range ( self .num,i, - 1 ):
self .date[j] = self .date[j - 1 ]
self .date[i] = value
self .num + = 1
#删除某一位置的操作
def remove( self ,i):
if not isinstance (i, int ):
raise TypeError
if i < 0 and i > = self .num:
raise IndexError
for j in range (i, self .num):
self .date[j] = self .date[j + 1 ]
self .num - = 1
#输出操作
def printList( self ):
for i in range ( 0 , self .num):
print self .date[i]
#销毁操作
def destroy( self ):
self .__init__()
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/xzfreewind/article/details/74834226