Python 數據結構理解分享

来源:https://www.cnblogs.com/xiaoguan-bky/archive/2019/07/17/11203974.html
-Advertisement-
Play Games

分享學習Python數據結構的一些理解,主要包含序列(如列表和元組),映射(如字典)以及集合3中基本的數據結構,以及可變和不可變數據類型。 ...


  摘要:分享學習Python數據結構的一些理解,主要包含序列(如列表和元組),映射(如字典)以及集合3中基本的數據結構,以及可變和不可變數據類型。

  Python 中的數據結構是根據某種方式將數據元素組合起來形成的一個數據元素集合,其中主要包含序列(如列表和元組),映射(如字典)以及集合3中基本的數據結構。幾乎所有的Python數據結構都可以歸結為這3種數據結構類型。

1.數據類型結構總表

  Python數據結構除了分為序列(如列表和元組),映射(如字典)以及集合3中基本的數據結構外,也可區分為可變數據類型與不可變數據類型。

  (1)可變數據類型

  通過可變數據類型,可以直接對數據結構對象的內容進行修改(並非是重新對對象賦值操作,即可以對數據結構對象進行元素的賦值修改、刪除或增加等操作。由於可變數據類型對象能直接對自身進行修改,所以修改後的新結果仍與原對象引用同一個id地址值,即由始至終只對同一個對象進行了操作。 Python中比較重要的可變數據類型包括列表、字典、可變集合等。

  (2)不可變數據類型

  與可變數據類型不同,不可變數據類型不能對數據結構對象的內容進行修改操作,不可對對象中的元素進行增加、刪除和賦值修改。若需要對對象進行內容修改,則需要對其變數名進行重新賦值,賦值操作會把變數名指向一個新對象,新舊對象兩者引用兩個不同的id地址值。常用的不可變數據類型包括數字、字元串、元組、不可變集合等。

2.序列類型

  序列是數據結構對象的有序排列,數據結構對象作為序列的元素都會被分配一個位置編號(也稱為索引),序列就相當於數學中數列的概念。Python中的序列類型包括字元串(string)、列表(list)、元組(tuple)、Unicode字元串、 buffer對象、 Xrange對象等數據結構,其中字元串、列表和元組最為常用。

字元串特點:

  • "任何在這雙引號之間的文字”;
  • "單引號其實和雙引號完全一樣”;
  • '''三個引號被用於長段文字

     或說明,只要引號不結束,你就可以任意

     換行''’;

  • 字元串屬不可變數據類型。

列表特點:

  • 列表創建在[ ]中,例[12,’dog’,’貓’]
  • 列表中每個元素都是可變的;
  • 列表中的元素是有序的,每個元素對應一個位置;
  • 列表可以容納Python中的任何對象。

元組特點:

  • 元祖創建在( )中,例(55,’app’,’a’,’p’,’p’)
  • 元祖中每個元素都是不可變的;
  • 元祖中的元素是有序的,每個元素對應一個位置。

3.映射類型

  映射類型就是存儲了對象與對象之間的映射關係的數據結構類型, Python中唯一的映射類型數據結構是字典( dictionary),字典中的每個元素都存在相應的名稱(稱為鍵)與之一一對應。字典相當於帶有各自名稱的元素組成的集合。與序列不同的是,字典中的元素並沒有排列順序。

字典特點:

  • 字典創建在{ }中,例{key1:value1,,key2:value2,key3:value3,}
  • 元素是鍵值對是無序、可變的,但鍵不變且不允許重覆,值可變;
  • 鍵-值成對出現;
  • 鍵不能重覆;
  • 鍵不可更改,值可修改;
  • 鍵來索引值。

4.集合類型

  除了上述基本數據結構類型外, Python還提供了一種稱為集合的數據結構。集合當中的元素不能重覆出現,即集合中的元素是相對唯一的,並且元素不存在排列順序。由此可以看出, Python中的集合概念相當於數學中的集合概念。集合類型包括可變集合(set)與不可變集合( frozenset)。

集合特點:

  • 集合創建在{ }中,例{1,2,3,’a’,’b’,’c’}
  • 集合是無序的;
  • 集合不能重覆,不可更改。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Django基礎二之URL路由系統 MVC和MTV框架 MVC Web伺服器開發領域里著名的MVC模式,所謂MVC就是把Web應用分為模型(M),控制器(C)和視圖(V)三層,他們之間以一種插件式的、松耦合的方式連接在一起,模型負責業務對象與資料庫的映射(ORM),視圖負責與用戶的交互(頁面),控制 ...
  • 閱讀目錄 一、三大編程範式 編程範式即編程的方法論,標識一種編程風格: 大家學習了基本的python語法後,大家可以寫python代碼了,然後每個人寫代碼的風格不同,這些不同的風格就代表了不同的流派; 如果把python的基本語法比作武術的基本功,那麼不同的編程風格就好比不同的武林門派。 雖然大家風 ...
  • 前面介紹瞭如何使用畫筆工具Graphics繪製各種圖案,然而Graphics並不完美,它的遺憾之處包括但不限於:1、不能設置背景顏色;2、雖然提供了平移功能,卻未提供旋轉功能與縮放功能;3、只能在控制項上作畫,無法將整幅畫保存為圖片;有鑒於此,AWT提供了Graphics的升級版名叫Graphics2 ...
  • 11-3 雇員:編寫一個名為Employee的類,其方法__init__() 接受名、姓和年薪,並將它們都存儲在屬性中。編寫一個名為give_raise()的方法,它預設將年薪增加5000美元,但也能夠接受其他的年薪增加量。 為Employee編寫一個測試用例,其包含兩個測試方法:test_give ...
  • a=1 聲明變數 a 變數的名字 = 賦值 1 值 變數定義的規則: 1. 變數由數字,字母,下劃線組成(不能加空格): a a_1 a1 2. 不能以數字開頭 3. 不能使用python中的關鍵字(寫的時候變藍了) 4. 不能使用中文和拼音 5. 區分大小寫 6. 變數名要具有描述性 7. 推薦寫 ...
  • SpringBoot快速入門--環境搭建 1、創建web工程 1.1 創建新的工程。 1.2 選擇maven工程,點擊下一步。 1.3 填寫groupid(maven的項目名稱)和artifactid(項目模塊)。點擊下一步 1.4 確認自己的項目路徑後,點擊finish。 2、添加springbo ...
  • github: 主頁: 使用手冊: LMDIF使用說明 官方英文介紹: 包括函數名 ,` lmdif1_` 最小化非線性函數平方和 函數概要 詳細描述 的目的是最小化m個n元非線性方程的平方和,使用的方法是LM演算法的改進。用戶需要提供計算方程的子程式。Jacobian矩陣會通過一個前向差分(forw ...
  • 這是一張簡單的service的繼承圖。可以看到我們的執行類,即XxxServiceImpl的繼承關係。 從上到下,ServiceImpl和BaseMapper是一個依賴關係,ServiceImpl和Iservice是一個實現關係。即ServiceImpl實現了IService中定義的方法,這裡為什麼 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...