一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - python數據結構之線性表的順序存儲結構

python數據結構之線性表的順序存儲結構

2021-04-05 00:13PyTi Python

這篇文章主要為大家詳細介紹了python數據結構之線性表的順序存儲結構,具有一定的參考價值,感興趣的小伙伴們可以參考一下

用Python仿照C語言來實現線性表的順序存儲結構,供大家參考,具體內容如下

本文所采用的數據結構模板為 《數據結構教程》C語言版,李春葆、尹為民等著。

該篇所涉及到的是線性表的順序存儲結構。

代碼:

?
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
# !/usr/bin/env python
# -*- coding: utf-8 -*-
 
__author__ = 'MrHero'
 
 
class Node(object):
  """
  線性表的存儲結構
  和 C 語言中的鏈式存儲結構類似
  """
  def __init__(self, data=None):
    self.data = data
    self.next = None
 
 
class LKList(object):
  """
  線性表的具體操作
  """
 
  def __init__(self):
    """
    相當于初始化線性表, 即創建頭結點
    頭節點為空節點,占據位置號為0
    創建好的表即為: 頭節點[0]->節點[1]->節點[2]->節點[3]->節點[4]
    :return:
    """
    self.L = Node(None)
    self.L.next = None
    self.length = 0
 
  def is_empty(self):
    """
    判斷線新表的長度
    :return:
    """
    return self.length == 0
 
  def get_length(self):
    """
    獲取線新表的長度
    :return:
    """
    return self.length
 
  def insert(self, i, elem):
    """
    在指定位i處置插入元素elem
    :param i: 指定的位置
    :param elem: 插入的元素elem
    :return:
    """
    j = 0
    p = self.L
    while j < i-1 and p is not None: # 查找第 i-1 個節點
      j += 1
      p = p.next
    if p is None# 未找到邏輯位序為 i-1 的節點
      raise IndexError("Index is out of range!")
    else# 找到邏輯位序為 i-1 的節點
      tmp = Node(elem)
      tmp.next = p.next
      p.next = tmp
      self.length += 1
 
  def delete(self, i):
    """
    刪除指定節點的元素
    :param i: 指定節點
    :return: 刪除的指定節點元素值
    """
    if self.is_empty():
      raise IndexError("The list is empty!")
    elif 0 < i <= self.length:
      j = 1
      p = self.L
      while j < i and p:
        p = p.next
        j += 1
      delelte_node = p.next
      p.next = delelte_node.next
      self.length -= 1
      return delelte_node.data
    else:
      raise IndexError("Index is out of range!")
 
  def get_elem(self, i):
    """
    獲取某個節點的值
    :param i:
    :return:返回某個節點的值
    """
    if self.is_empty():
      raise IndexError("The list is empty")
    elif 0 < i <= self.length:
      j = 0
      p = self.L
      while j < i and p:
        p = p.next
        j += 1
      print p.data
    else:
      raise IndexError("Index is out of range!")
 
  def locate_elem(self, elem):
    """
    查找某值的位置
    :param elem:
    :return: 返回第一個值等于elem的位置
    """
    j = 0
    p = self.L
    while p is not None and p.data != elem:
      p = p.next
      j += 1
    if p is Node:
      return -1
    else:
      return j
 
  def create_dict_list_H(self, list):
    """
    頭插法建表
    :param list:
    :return:
    """
    p = self.L
    for i in range(len(list)):
      tmp = Node(list[i])
      tmp.next = p.next
      p.next = tmp
      self.length += 1
 
  def create_dict_list_E(self, list):
    """
    尾插法建表
    :param list:
    :return:
    """
    p = self.L
    r = p
    for i in range(len(list)):
      tmp = Node(list[i])
      r.next = tmp
      r = tmp
      self.length += 1
    r.next = None
 
  def show_lklist(self):
    if self.is_empty():
      raise IndexError("It's a empty list!")
    else:
      j = 1
      p = self.L
      while j <= self.length and p:
        p = p.next
        if p is not None:
          print p.data
        j += 1
 
 
if __name__ == '__main__':
  lk = LKList()
  #
  # lk.create_dict_list_E([1, 2, 3, 4])
  # print "-----"
  # lk.get_elem(1)
  # lk.get_elem(2)
  # lk.get_elem(3)
  # lk.get_elem(4)
  # print "-------"
  # lk.show_lklist()
  # lk.insert(3, 5)
  # print "-------"
  # lk.show_lklist()
  # lo = lk.locate_elem(5)
  # print "location is %d" % lo
  # lk.delete(4)
  # print "-------"
  # lk.show_lklist()

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/lqzhouxx/article/details/40846177

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美3p大片在线观看完整版 | 男同gay作爰视频网站 | 91麻豆网址| 91精品国产99久久 | 国产精品免费综合一区视频 | 农夫69小说小雨与农村老太 | 好男人影视社区www在线观看 | 晓雪老师我要进你里面好爽 | 99久久免费看国产精品 | 天天舔天天干天天操 | 久久热r在线视频精品 | a级影视 | www.好吊操| 亚洲福利精品电影在线观看 | 国产婷婷成人久久av免费高清 | 午夜想想爱 | 1313午夜精品久久午夜片 | 四虎最新永久免费网址 | 精品久久免费观看 | 欧洲vodafonewi精品 | 脱了白丝校花的内裤猛烈进入 | www.俺去啦 | 亚洲 欧美 清纯 校园 另类 | 毛片资源| 日本护士厕所xxx | 亚洲区精品 | 青青青国产手机在线播放 | 超级碰在线视频 | 日韩一区二区三区四区不卡 | 俄罗斯一级淫片 | 美女扒开腿让男生捅 | 好大用力深一点 | 日本在线你懂的 | 成人国产在线播放 | 国产一区二区三区毛片 | 男女拍拍拍免费视频网站 | 精品一区视频 | 97午夜 | 国产精品日韩欧美一区二区 | 99热导航| 欧美影院一区二区 |