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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...