資料結構--順序表定義及python實現__資料結構

來源:互聯網
上載者:User

       順序表即線性表的順序儲存結構。它是通過一組地址連續的儲存單元對線性表中的資料進行儲存的,相鄰的兩個元素在物理位置上也是相鄰的。比如,第1個元素是儲存線上性表的起始位置LOC(1),那麼第i個元素即是儲存在LOC(1)+(i-1)*sizeof(ElemType)位置上,其中sizeof(ElemType)表示每一個元素所佔的空間。


   

下面是順序表的python實現:

#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__()


相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.