C語言數(shù)組學(xué)習(xí)之特殊矩陣的壓縮存儲(chǔ)
首先最開始我們先回憶一下數(shù)組的概念
1.數(shù)組的定義
數(shù)組是由n個(gè)相同類型的數(shù)據(jù)元素構(gòu)成的有限序列,每個(gè)數(shù)據(jù)元素稱為一個(gè)數(shù)組元素,每個(gè)元素在n個(gè)線性關(guān)系中的序號(hào)稱為該元素的下標(biāo),下標(biāo)的取值范圍稱為數(shù)組的維界。
數(shù)組與線性表的關(guān)系
數(shù)組是線性表的推廣
- 一維數(shù)組可以視為一個(gè)線性表
- 二維數(shù)組可視為其元素為定長線性表的線性表
- 數(shù)組一旦被定義,其維數(shù)和維界就不再改變,因此除了數(shù)組結(jié)構(gòu)的初始化和銷毀外,數(shù)組只能執(zhí)行存儲(chǔ)元素和修改元素的操作
在了解完數(shù)組的定義后,我們?cè)倭私庖幌聰?shù)組在內(nèi)存中是如何存儲(chǔ)的
2.數(shù)組的存儲(chǔ)結(jié)構(gòu)
一個(gè)數(shù)組的所有元素在內(nèi)存中占用一段連續(xù)的存儲(chǔ)空間
一維數(shù)組的存儲(chǔ)如下:
對(duì)于多維數(shù)組,比如二維數(shù)組來說,有兩種映射方法:按行優(yōu)先 和 按列優(yōu)先
按行優(yōu)先:先行后列,先存儲(chǔ)行號(hào)較小的元素,行號(hào)相等先存儲(chǔ)列號(hào)較小的元素
按列優(yōu)先:先列后行,先存儲(chǔ)列號(hào)較小的元素,列號(hào)相等先存儲(chǔ)行號(hào)較小的元素
習(xí)題1
在了解數(shù)組在內(nèi)存中的存儲(chǔ)方式后,我們可以開始用數(shù)組來存儲(chǔ)矩陣中的元素了!
3.對(duì)稱矩陣
概念
對(duì)于一個(gè)n階方陣A中的任意一個(gè)元素ai,j都有ai,j=aj,i,則稱為對(duì)稱矩陣
對(duì)于一個(gè)對(duì)稱矩陣我們可以將其中的元素劃分為3個(gè)部分:上三角區(qū),主對(duì)角線和下三角區(qū)
存儲(chǔ)方法選擇
土辦法
用一個(gè)n*n的數(shù)組去完完整整地將整個(gè)矩陣中的元素給存儲(chǔ)下來。
壓縮存儲(chǔ)法
我們發(fā)現(xiàn)對(duì)于n階對(duì)稱矩陣,上三角區(qū)的所有元素與下三角區(qū)的所有元素相同,若采用上述的土辦法,將會(huì)浪費(fèi)幾乎一半的空間,因此我們將其中重復(fù)相同的元素只存放一次。
存儲(chǔ)主對(duì)角線和下三角區(qū)
可見,采取行優(yōu)先的原則將主對(duì)角線和下三角區(qū)的元素存入數(shù)組B當(dāng)中
那么在數(shù)組B當(dāng)中,ai,j對(duì)應(yīng)B[?]呢?我們可以自己通過計(jì)算得出一個(gè)映射公式
習(xí)題1
習(xí)題2
4.三角矩陣
概念
存儲(chǔ)方法選擇
土辦法
用一個(gè)n*n的數(shù)組去完完整整地將整個(gè)矩陣中的元素給存儲(chǔ)下來。
壓縮存儲(chǔ)法
與對(duì)稱矩陣不同之處在于,存儲(chǔ)完下三角區(qū)和主對(duì)角線上的元素之后,緊接著存儲(chǔ)對(duì)角線上方的常量一次。
按行存儲(chǔ)主對(duì)角線和下三角區(qū)+常量C
按行存儲(chǔ)主對(duì)角線和上三角區(qū)+常量C
5.三對(duì)角矩陣
概念
對(duì)角矩陣稱為帶狀矩陣;在三對(duì)角矩陣中,所有非零元素都集中在以主對(duì)角線為中心的3條對(duì)角線的區(qū)域,其他區(qū)域的元素都為零
存儲(chǔ)方法選擇
壓縮存儲(chǔ)法
習(xí)題1
6.稀疏矩陣
概念
矩陣中非零元素的個(gè)數(shù)t,相對(duì)矩陣元素的個(gè)數(shù)s來說非常少,即s>>t的矩陣稱為稀疏矩陣。
存儲(chǔ)方法選擇
三元組存儲(chǔ)
十字鏈表法
?
到此這篇關(guān)于C語言數(shù)組學(xué)習(xí)之特殊矩陣的壓縮存儲(chǔ)的文章就介紹到這了,更多相關(guān)C語言 矩陣的壓縮存儲(chǔ)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
c語言根據(jù)用戶輸入的出生年份并計(jì)算出當(dāng)前年齡
這篇文章主要介紹了c語言根據(jù)用戶輸入的出生年份并計(jì)算出當(dāng)前年齡,需要的朋友可以參考下2023-03-03詳解MFC/C++調(diào)用易語言的整數(shù)型和文本型與VS2010互動(dòng)
在本篇文章里我們給大家分享了MFC/C++調(diào)用易語言的整數(shù)型和文本型與VS2010互動(dòng)相關(guān)知識(shí)點(diǎn)內(nèi)容,有興趣的朋友們可以參考下。2018-11-11關(guān)于C++多重繼承下虛表結(jié)構(gòu)的問題
這篇文章主要介紹了C++ 多重繼承下虛表結(jié)構(gòu)的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09c語言中位字段與結(jié)構(gòu)聯(lián)合的組合使用詳解
本篇文章是對(duì)c語言中位字段與結(jié)構(gòu)聯(lián)合的組合使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05詳細(xì)講解C語言中的數(shù)據(jù)以及位運(yùn)算
這篇文章主要為大家詳細(xì)介紹了C語言中數(shù)據(jù)表示方法以及位運(yùn)算的相關(guān)知識(shí)點(diǎn),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-06-06C語言qsort函數(shù)用冒泡排序?qū)崿F(xiàn)過程詳解
qsort函數(shù)是由C語言提供的標(biāo)準(zhǔn)庫函數(shù), 它的實(shí)現(xiàn)思想是快速排序。這篇文章主要介紹了C語言中qsort函數(shù)用法及用冒泡排序?qū)崿F(xiàn)qsort函數(shù)功能,需要的可以參考一下2023-02-02C++ 中boost::share_ptr智能指針的使用方法
這篇文章主要介紹了C++ 中boost::share_ptr智能指針的使用方法的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-10-10深入理解c++中char*與wchar_t*與string以及wstring之間的相互轉(zhuǎn)換
本篇文章是對(duì)c++中的char*與wchar_t*與string以及wstring之間的相互轉(zhuǎn)換進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05