12-數據結構-數組、矩陣、廣義表

數組、矩陣、廣義表


目錄

數組、矩陣、廣義表

? 一、數組

? ? ? ? 二.矩陣

三、廣義表



? 一、數組

????????這一章節理解基本概念即可。數組要看清其實下標是多少,并且二維數組,存取數據,要先看清楚是按照行存還是按列存,按行則是正常一行一行的去讀寫,按列則是,從左至右,一列一列的弄。

????????此外,數組中具體坐標的空間大小要會計算,每塊存儲單元,算到該數組坐標的前一位的數組大小:如A[5][3],起始位A[0][0],則計算A[5][3]的時候,先計算0-4行的空間大小,再計算第5行的大小,第五行的時候,是計算0-2列即0,1,2,三列,所以第五行空間個數為3,將其加上即可。

二、矩陣

????????則是掌握基本矩陣的代碼,矩陣相加,相乘,轉置。

  1. 其次要會壓縮矩陣,壓縮矩陣的目的是減少存儲單元
  2. 方法是,給矩陣中的有效數據,存進一維數組中去。
  3. 這個時候就需要壓縮矩陣的計算了,一般計算特殊矩陣:
  4. 對稱陣,上三角下三角,畫一個簡單的矩陣,然后根據按行存或者按列存,進行存儲,然后計算,一般是等差數列,然后加上最后一行或最后一列的有效數據,這個就看具體是多少了。一般遇到選擇題,讓求規律的,在看清矩陣和一維數組起始下標的前提下,找具體坐標試一下,如A[0][0]---0,在一維數組里面是第0個,給(行)i=0,(列)j=0,代入試一下即可。如果遇到算具體數值的,則是畫一個大概矩陣,然后找規律。按行排列,則先計算0到i-1行的個數(一般為等差數列,第0行有1個,第1行有2個第i-1行有i個,則共0到i-1,總個數為i個,a1=1,an=i所以等差數列為(\frac{i*(i+1)}{2}),這是第0到i-1行的總個數,再計算第i行的個數,按列算,j+1個,所以總個數為\frac{i*(i+1)}{2}+j+1,但存進數組的話,若數組下標為1,則\frac{i*(i+1)}{2}+j+1+1,要看具體矩陣和數組的起始下標。
  5. 對三角矩陣,則是待定系數法,為了省事直接k=ai+bj+c,其中k為存進一維數組的下標,i為矩陣的行,j為矩陣的列,c為常數,然后再去帶具體坐標去解方程組即可。但上面設的公式,還要看具體情況去設置,如果有的個數為等差數列,則肯定有行的平方或者列的平方。
  6. 之后是稀疏矩陣:矩陣中大部分都是0的矩陣。

稀疏矩陣的壓縮,就是給矩陣中非零元素,存起來。

稀疏矩陣的順序存儲(設成結構體,里面包含各種變量)

1.三元組表示法

按行優先存儲,所以稀疏矩陣三元組,不好逆置,逆置的話,需要按列重新搞一下。

????????三元組,就是數組結構體里定義三個變量,分別是行,列,以及坐標值。其中數組結構體,第一個里面存的是,矩陣信息,即共幾行幾列,有幾個非零元素。因此如果題中有5個非零元素,則三元組數組,要5+1個數組空間。

稀疏矩陣轉化三元組步驟:

????????1.先計算矩陣中非零元素個數。即二維數組遍歷,非零的,count(計數器)+1。最后返回count。

? ? ? ? 2.之后定義一個三元組數組,然后開始寫轉換函數,返回類型為三元組指針類型,即返回三元組。先存儲矩陣信息,再三元組數組第一個位置,隨后定義個記錄器,index=1,表示實際非零元素個數的下標,隨后開始遍歷,當矩陣元素不等于零的時候,存進index坐標下,隨后行和列也記錄,之后,index+1,后移動,直到遍歷結束。

2.偽地址存儲

數據結構體,里面變量為偽地址變量以及具體值。偽地址計算方法,可直接查,按照行或者列,從1開始,哪個位置非零,就記錄。

稀疏矩陣的鏈式存儲

1.鄰接表法。

用一維數組(矩陣行)去索引,索引內容,坐標值,列下標,以及同行下一個非零元。

即同一行,串成一個鏈,只串同行非零元素。

2.十字鏈表

三、廣義表

廣義表時線性表的推廣,不是線性表,而是層次結構,樹。

每個廣義表用()括住,廣義表里面可以套廣義表,每個廣義表是一個小整體。廣義表里面,可以由原子元素(單個值),可以是廣義表。

廣義表的深度,長度和表頭表尾

深度:最多的層數,即廣義表包含幾個,查括號。化成樹的話,為最底下的那個廣義表。

長度:第一層元素個數,化成樹的話,是第二層結點.

表頭:廣義表非空時,第一個元素。即表頭為取第一個元素的值。

表尾:實際上是除了表頭以外,其他構成的新的廣義表。是個廣義表。

例如:((a),(b,f),(v))

表頭為:(a)//只包含a的廣義表,? 不是a,a是原子元素。

表尾:((b,f)(v)),新構成的廣義表.

再對表尾求

表頭:(b,f),廣義表。? ?不是((b,f)),表頭為取第一個元素

表尾:( (v) ),是個廣義表,由廣義表(v)構成,即刪除表頭,剩下組成的新的廣義表,


廣義表的鏈式存儲

有兩個結點,第一個為廣義表結點,包含標記域,表頭,表尾指針,第二個是原子元素結點,包含標記域,和具體值。其中標記域為1,表示廣義表,標記域為0表示原子元素。

一般,先畫出第一個廣義表結點,然后頭節點指向出來,尾指針指向尾結點,以此類推。

擴展的線性表存儲結構

跟鏈式存儲差不多,只不過后面的指針變成了,左孩子又兄弟了,頭指針指向最左邊的孩子,之后孩子的尾指針,指向同級的右兄弟。(這種一般先畫成樹的形式,好判斷)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/37597.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/37597.shtml
英文地址,請注明出處:http://en.pswp.cn/news/37597.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

學習Vue:slot使用

在Vue.js中,組件高級特性之一是插槽(Slots)。插槽允許您在父組件中插入內容到子組件的特定位置,從而實現更靈活的組件復用和布局控制。本文將詳細介紹插槽的使用方法和優勢。 什么是插槽? 插槽是一種讓父組件可以向子…

AIF360入門教學

1、AIF360簡介 AI Fairness 360 工具包(AIF360)是一個開源軟件工具包,可以幫助檢測和緩解整個AI應用程序生命周期中機器學習模型中的偏見。在整個機器學習的過程中,偏見可能存在于初始訓練數據、創建分類器的算法或分類器所做的預測中。AI Fairness 360…

OPENCV C++(十一)

鼠標響應函數 //鼠標響應函數 void on_mouse(int EVENT, int x, int y, int flags, void* userdata) {Mat hh;hh *(Mat*)userdata;switch (EVENT){case EVENT_LBUTTONDOWN:{vP.x x;vP.y y;drawMarker(hh, vP, Scalar(255, 255, 255));//circle(hh, vP, 4, cvScalar(255, 255…

人工智能在監控系統中的預測與優化:提升效率和響應能力

引言:人工智能的發展給監控系統帶來了新的可能性,通過分析歷史監控數據和其他相關數據,人工智能可以預測未來可能發生的事件,如交通擁堵、安全隱患等,并幫助優化監控系統的配置和資源分配。這種預測和優化的能力可以提…

2023年國賽數學建模思路 - 復盤:校園消費行為分析

文章目錄 0 賽題思路1 賽題背景2 分析目標3 數據說明4 數據預處理5 數據分析5.1 食堂就餐行為分析5.2 學生消費行為分析 建模資料 0 賽題思路 (賽題出來以后第一時間在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 1 賽題背景 校園一卡通是集…

vue3表格,編輯案例

index.vue <script setup> import { onMounted, ref } from "vue"; import Edit from "./components/Edit.vue"; import axios from "axios";// TODO: 列表渲染 const list ref([]); const getList async () > {const res await ax…

6.2.0在線編輯:GrapeCity Documents for Word (GcWord) Crack

GrapeCity Word 文檔 (GcWord) 支持 Office Math 函數以及轉換為 MathML GcWord 現在支持在 Word 文檔中創建和編輯 Office Math 內容。GcWord 中的 OMath 支持包括完整的 API&#xff0c;可處理科學、數學和通用 Word 文檔中廣泛使用的數學符號、公式和方程。以下是通過 OMa…

無法在 macOS Ventura 上啟動 Multipass

異常信息 ? ~ sudo multipass authenticate Please enter passphrase: authenticate failed: Passphrase is not set. Please multipass set local.passphrase with a trusted client. ? ~ multipass set local.passphrase Please enter passphrase: Please re-enter…

大語言模型LLM的一些點

LLM發展史 GPT模型是一種自然語言處理模型,使用Transformer來預測下一個單詞的概率分布,通過訓練在大型文本語料庫上學習到的語言模式來生成自然語言文本。 GPT-1(117億參數),GPT-1有一定的泛化能力。能夠用于和監督任務無關的任務中。GPT-2(15億參數),在生成方面表現出很…

vue自定義指令--動態參數綁定

在企業微信側邊欄應用中&#xff0c;給dialog添加了拖拽功能&#xff0c;但是因為dialog高度超過了頁面高度&#xff0c;所以高度100%時拖拽有個bug--自動貼到窗口頂部而且企業側邊欄寬高都有限制&#xff0c;拖拽效果并不理想&#xff0c;所以就想縮小dialog再進行拖拽。 拖拽…

IntelliJ IDEA和Android studio怎么去掉usage和作者提示

截止到目前我已經寫了 600多道算法題&#xff0c;其中部分已經整理成了pdf文檔&#xff0c;目前總共有1000多頁&#xff08;并且還會不斷的增加&#xff09;&#xff0c;大家可以免費下載 下載鏈接&#xff1a;https://pan.baidu.com/s/1hjwK0ZeRxYGB8lIkbKuQgQ 提取碼&#xf…

java處理CSV文件

文章目錄 1. 方法2. maven依賴3. 示例代碼 1. 方法 opencsv–>CSVParser&#xff1b;commons-csv–>CSVReader&#xff1b;有時候文本里有逗號可能會導致錯誤分割 2. maven依賴 <dependency><groupId>org.apache.commons</groupId><artifactId>…

457. 環形數組是否存在循環

457. 環形數組是否存在循環 原題鏈接&#xff1a;完成情況&#xff1a;解題思路&#xff1a;參考代碼&#xff1a;經驗吸取 原題鏈接&#xff1a; 457. 環形數組是否存在循環 https://leetcode.cn/problems/circular-array-loop/description/ 完成情況&#xff1a; 解題思路…

使用Pandas進行數據清理的入門示例

數據清理是數據分析過程中的關鍵步驟&#xff0c;它涉及識別缺失值、重復行、異常值和不正確的數據類型。獲得干凈可靠的數據對于準確的分析和建模非常重要。 本文將介紹以下6個經常使用的數據清理操作&#xff1a; 檢查缺失值、檢查重復行、處理離群值、檢查所有列的數據類型…

explicit關鍵字 和 static成員

explicit關鍵字 和 static成員 1、explicit 關鍵字2、static成員&#xff08;靜態成員變量屬于類的&#xff08;只有所屬這個類的對象才能修改&#xff09;&#xff0c;不同于全局變量&#xff08;任何對象都能修改&#xff09;&#xff09;2.1 定義和性質2.2 靜態成員的使用場…

opencv進階02-在圖像上繪制多種幾何圖形

OpenCV 提供了方便的繪圖功能&#xff0c;使用其中的繪圖函數可以繪制直線、矩形、圓、橢圓等多種幾何圖形&#xff0c;還能在圖像中的指定位置添加文字說明。 OpenCV 提供了繪制直線的函數 cv2.line()、繪制矩形的函數 cv2.rectangle()、繪制圓的函數cv2.circle()、繪制橢圓的…

【Quarkus技術系列】「云原生架構體系」在云原生時代下的Java“拯救者”是Quarkus,那云原生是什么呢?

云原生時代下的Java"拯救者" 在云原生時代&#xff0c;其實Java程序是有很大的劣勢的&#xff0c;以最流行的spring boot/spring cloud微服務框架為例&#xff0c;啟動一個已經優化好&#xff0c;很多bean需要lazy load的application至少需要3-4秒時間&#xff0c;內…

廣西一公司泄露22萬個人信息,被罰23萬

近日&#xff0c;廣西北海公安網安部門發現&#xff0c;北海某公司網站存在嚴重數據泄露問題&#xff0c;約22萬個人信息數據已掛在暗網售賣。 經查&#xff0c;涉案公司主要提供網上咨詢服務&#xff0c;在日常工作中收集了個人和企業等大量公民信息&#xff0c;但公司存放數…

【算法題】2547. 拆分數組的最小代價

題目&#xff1a; 給你一個整數數組 nums 和一個整數 k 。 將數組拆分成一些非空子數組。拆分的 代價 是每個子數組中的 重要性 之和。 令 trimmed(subarray) 作為子數組的一個特征&#xff0c;其中所有僅出現一次的數字將會被移除。 例如&#xff0c;trimmed([3,1,2,4,3,4…

一站式自動化測試平臺-Autotestplat

3.1 自動化平臺開發方案 3.1.1 功能需求 3.1.3 開發時間計劃 如果是剛入門、但有一點代碼基礎的測試人員&#xff0c;大概 3 個月能做出演示版(Demo)進行自動化測試&#xff0c;6 個月內勝任開展工作中項目的自動化測試。 如果是有自動化測試基礎的測試人員&#xff0c;大概 …