數據結構(java版)學習筆記(一)——線性表

来源:https://www.cnblogs.com/kexing/archive/2018/07/29/9309188.html
-Advertisement-
Play Games

一、線性表的定義 線性表是n(n>=0)個具有相同特性的數據元素的有限序列。 線性表是最簡單、最常用的一種數據結構 線性表屬於線性結構的一種 如果一個數據元素序列滿足: (1)除第一個和最後一個數據元素外,每個數據元素只有一個前驅數據元素和一個後繼數據元素; (2)第一個數據元素沒有前驅數據元素; ...


一、線性表的定義

線性表是n(n>=0)個具有相同特性的數據元素的有限序列。

線性表是最簡單、最常用的一種數據結構

線性表屬於線性結構的一種

 

 

如果一個數據元素序列滿足:

 

(1)除第一個和最後一個數據元素外,每個數據元素只有一個前驅數據元素和一個後繼數據元素;

 

(2)第一個數據元素沒有前驅數據元素;

(3)最後一個數據元素沒有後繼數據元素

則可以稱這樣的數據結構為線性結構

二、線性表的種類

線性表的存儲結構主要有兩種,順序存儲結構鏈式存儲結構

順序存儲結構的存放的線性表稱作為順序表,用鏈式存儲結構存放的線性表稱為線性鏈表

按照這個說法,之前所提到的java中的int數組等一維數組都是可以稱為順序表。

使用鏈式存儲結構,則會有前趨和後繼的說法

下列的圖可以說明一點(圖就這樣子了,別吐槽了。。)

A1作為開頭,所以沒有前趨,A1的後繼是A2

A2的前趨是A1,後繼則是A3

A3是末尾,所以沒有後繼,A3的前趨是A2

 

三、線性表的運算

基本運算都在圖中了,這裡就不多寫了,由於我們是使用java語言描述的,所以我們可將運算寫成一個介面(抽象類),之後再由類去實現此介面,覆寫這些方法,可能這樣說大家都不是很理解,沒有關係,在下一節就會使用到此介面了

 

public interface ListIntf {
    public int size(); //返回表的長度
    public void clear(); //重置表為空表
    public boolean isEmpty(); //判斷表是否為空
    public String get(int i); //取得表中第i個元素的值
    public int indexOf(String s);//獲得表中與數據元素s相等的第一個元素的位置(位序)
    public String getPre(String s);//獲得數據元素s的前趨
    public String getNext(String s);//獲得數據元素s的後繼
    public void insertElementAt(String s,int i);//在第i個位置之前插入新的數據元素s,表長度加1
    public String remove(int i);//刪除第i個數據元素,並返回其值,表長度減1
    public String remove(String s); //刪除數據元素s,並返回其值,表長度減1
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 給定一組(串)數據,根據輸入得號碼,查詢歸屬地 如有錯誤,感謝指正! ...
  • Exchanger應該算併發包中工具使用相對少的,因為它主要用於線程之間交換數據,它的用法比較簡單在不同線程之間使用exchange方法交換數據,但是內部實現比較巧妙,使用了unsafe的CAS原子操作、自旋來解決衝突問題,下麵我們通過源碼一探究竟。 ...
  • 前言 Mybatis的緩存主要有兩種: 系統緩存,也就是我們一級緩存與二級緩存; 自定義的緩存,比如Redis、Enhance等,需要額外的單獨配置與實現,具體日後主要學習介紹。 在這裡主要記錄系統緩存的一些簡單概念, 並沒有涉及原理。其中會涉及Mybatis的相關配置以及生命周期等。 主要參考資料 ...
  • Java高級編程 掌握 類的定義; 對象的定義; 類的構造方法; 方法的重載 實現步驟: 新建Worker類 為Worker類添加四個屬性 為Worker類添加帶參的構造方法,不帶參的構造方法不再自動創建 創建不帶參數的構造方法 為Worker類添加getTax()方法 為Worker類添加getS ...
  • 題意 板子題,題意很清楚吧。。 Sol 很顯然可以直接上LCT。。 但是這題允許離線,於是就有了一個非常巧妙的離線的做法,好像叫什麼線段樹分治?? 此題中每條邊出現的位置都可以看做是一段區間。 我們用線段樹維護。線段樹的每個節點維護一個vector表示覆蓋了當前節點的邊的存在區間 因為總的邊數是$M ...
  • 一:虛擬機記憶體圖解 JAVA程式運行與虛擬機之上,運行時需要記憶體空間。虛擬機執行JAVA程式的過程中會把它管理的記憶體劃分為不同的數據區域方便管理。 虛擬機管理記憶體數據區域劃分如下圖: 數據區域分類: 方法區 (Method Area) 虛擬機棧 (VM Stack) 本地方法棧 (Native Me ...
  • 其實在轉正之後我就想抽個時間好好的梳理一下我的 Java 上車之路 ,但是一直拖到現在 ,因為有學弟問到 ,所以也就給了我動力 。畢竟答應了人家的事要做到 。 首先要有相應的背景介紹 ,不然說個毛線啊 ,大家不在同一水平 ,不好參考借鑒 。我呢 ,學校很牛逼 ,是一所剛過線的二本 ,自身的成績在班裡 ...
  • Chrome開發者工具中Network功能介紹 第一列Name:請求的名稱,一般會將URL的最後一 部分內容當作名稱。 第二列Status: 響應的狀態碼,這裡顯示為200,代表響應是正常的。通過狀態碼,我們可 以判斷發送了請求之後是否得到了正常的響應。 第三列Type: 請求的文檔類型。這裡為do ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...