欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

數(shù)據(jù)結(jié)構(gòu) 數(shù)組順序存儲詳細介紹

 更新時間:2017年05月23日 17:11:00   投稿:lqh  
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu) 數(shù)組順序存儲詳細介紹的相關(guān)資料,需要的朋友可以參考下

數(shù)據(jù)結(jié)構(gòu) 數(shù)組順序存儲

          最近學習數(shù)據(jù)結(jié)構(gòu),看到數(shù)組順序存儲,很是頭昏,看不懂,很多東西,這里在網(wǎng)上找了比較詳細的資料,大家好好看注釋內(nèi)容:

#include<stdarg.h>  
#define MAX_ARRAY_DIM 8 //假設(shè)數(shù)組維數(shù)的最大值為8 
typedef struct {
 ElemType *base;  //數(shù)組元素基址,由InitArray分配
 int dim;  //數(shù)組維數(shù)
 int *bounds;  //數(shù)組維界基址,由InitArray分配
 int *constants;  //數(shù)組映象函數(shù)常量基址,由InitArray分配
}Array;

Status InitArray(Array &A,int dim,...){//這里用的是“可變參”形參方式。它主要解決維數(shù)不定的問題。
//舉例:設(shè)有4維數(shù)組,各維分別是:4,5,6,7(這些數(shù)字是隨意給的),那么,調(diào)用方式:
//InitArray(ar, 4, 4, 5, 6, 7);
//ar其中,ar也是假設(shè)的變量名稱, 4表示數(shù)組有4維, 4, 5, 6, 7這4個數(shù)是各維大小
//如果是5維的,那么就這樣:
//InitArray(ar, 5, 第一維數(shù),第二維數(shù),第三維數(shù),第四維數(shù),第五維數(shù));
//若維數(shù)dim和隨后的各維長度合法,則構(gòu)造相應(yīng)的數(shù)組A,并返回OK。
if (dim<1 ||dim>MAX_ARRAY_DIM) return ERROR;
A.dim=dim;
A.bounds=(int *)malloc(dim*sizeof(int));
if (!A.bounds) exit(OVERFLOW);
//若各維長度合法,則存入A.bounds,并求出A的元素總數(shù)elemtotal。
elemtotal=1;
va_start(ap,dim); //ap為va_list類型,是存放變長參數(shù)表信息的數(shù)組。
for (i=0;i<dim;++i){
 A.bounds[i]=va_arg(ap,int);//從這里可以看出,A.bounds數(shù)組中,存放的是各維的大小
 if (A.bounds[i]<0) return UNDERFLOW;
 elemtotal * = A.bounds[i];//各維數(shù)之積,自然是數(shù)組中元素的總個數(shù)
}
va_end(ap);
A.base=(ElemType *)malloc(elemtotal *sizeof(ElemType));//這個就是“多維數(shù)組”的存儲本質(zhì):一維數(shù)組!
//用一維方式表示多維數(shù)組后(其實,從管理和使用的角度看,內(nèi)存就只有一維這么一種形式),存在如何按“多維”的邏輯角度定位元素的問題。再說清楚些:假設(shè)前面所講的4維數(shù)組,其元素用下標形式表示,范圍為:(0,0,0,0)到(3,4,5,6)。對于任意下標(在有效范圍內(nèi))(i1, i2, i3, i4)所對應(yīng)的元素,轉(zhuǎn)換到“一維”空間后,其下標應(yīng)該是什么?這就是這個程序后面要處理的主要問題。
if (!A.base) exit (OVERFLOW):
//求映象函數(shù)的常數(shù)ci(i為下標),并存入A.constants[i-1],i=1,...dim。
A.constants=(int *)malloc(dim *sizeof(int));
if (!A.constants)exit (OVERFLOW);
//以前面的4維數(shù)組為例子,其中A.bounds[0]=4,A.bounds[1]=5,A.bounds[2]=6,A.bounds[3]=7。
//跟蹤下面的程序:
A.constants[dim-1]=1;//A.constants[3] = 1
for (i=dim-2;i>=0;--i)//A.constants[2] = 7,A.constants[1] = 6*7,A.constants[0] = 5*6*7
 A.constants[i]=A.bounds[i+1] * A.constants[i+1];
//說到這里,這個問題就清晰了:A.constants中的元素,是幫助定位用的。比如說:對于(2,0,0,0)這個下標的元素,應(yīng)該越過前面的(0,0,0,0)~(0,4,5,6)和(1,0,0,0)~(1,4,5,6)這兩大塊,而這兩大塊中的每一塊都有5*6*7個元素,這正好就是A.constants[0]中所存放的數(shù)據(jù)?。?
//現(xiàn)在應(yīng)該明白了吧!
return OK;
}

status Locate(Array A,va_list ap,int &off){
//若ap指示的各下標值合法,則求出該元素在A中相對地址off。
 off=0;
 for (i=0;i<A.dim;++i){
 ind=va_arg(ap,int);
 if (ind<0 || ind>=A.bounds[i]) return OVERFLOW;
 off + = A.constants[i] * ind;
 }
 return OK;

補充:為什么A.constants[dim-1]

bounds存的就是每一維里面的個數(shù),constants保存的是每一個維度如果下標增加1,那個對應(yīng)到內(nèi)存空間的下標應(yīng)該增加多少。說起來比較抽象,我們假設(shè)是3維,就比較容易說清楚了,首先把3維看作有bounds[0]那么高,對于每一個0到bounds[0]-1的范圍內(nèi),就是一個平面,這個平面有bounds[1]那么長,bounds[2]那么寬。那么,我們把高=0,長=0,寬=0對應(yīng)到內(nèi)存的第一個位置,高=0,長=0,寬=1的對應(yīng)到第二個位置,那么高=0,長=1,寬=0應(yīng)該放在什么位置呢?顯然就是0+bounds[2]這個位置。那么高=1,長=0,寬=0的那個元素應(yīng)該在哪個位置呢?顯然是高=0這一個平面放完了之后的那個位置,高=0這個平面有長度*寬度那么多個元素,也就是bounds[1]*bounds[2]這么多個元素,所以高=1,長=0,寬=0這個元素就應(yīng)該在0+bounds[1]*bounds[2]這個位置,對吧。假設(shè)還有第四維度,我們假設(shè)這個維度代表時間吧,那時間=0,高=0,長=0,寬=0的元素放在內(nèi)存第0個位置,那么時間=1,高=0,長=0,寬=0的元素是不是應(yīng)該放在0+bound[1]*bound[2]*bound[3]這個位置呢。這就是A.constants[i]=A.bounds[i+1] * A.constants[i+1];這個公式的來歷。當然,我只是很簡單的解釋了,很多細節(jié)需要你自己考慮,因為語言表示起來太復雜了,不知道怎么表述。。。
其實你仔細看A.constants[i]=A.bounds[i+1] * A.constants[i+1];,這是一個遞推公式,把它展開的話,下面我就把constants[i]簡寫為coni,bounds[i]簡寫為boni那么con i= bon[i+1]*con[i+1]=bon[i+1]*bon[i+2]*con[i+2] = bon[i+1]*bon[i+2]*bon[i+3]*con[i+3]=bon[i+1]*bon[i+2]*bon[i+3]*...*bon[dim]你看這個公式是不是就是相當于上面說的高度*長度*寬度? 剛才那個bon[dim]應(yīng)該寫成bon[dim-1]不過這個不影響理解。

然后我們看最后一維,例如上面例子的寬度,寬度+1是不是就正好內(nèi)存地址+1呢?于是對應(yīng)寬度這個最后的維度,每次地址只需+1就能訪問下一個元素,因此bon[dim-1]也就是最后一維的,是不是就應(yīng)該等于1呢。。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • Qt中利用QTextBrowser控件設(shè)計日志窗口

    Qt中利用QTextBrowser控件設(shè)計日志窗口

    本文主要介紹了Qt中利用QTextBrowser控件設(shè)計日志窗口,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-06-06
  • C語言編程計算信噪比SNR理解學習

    C語言編程計算信噪比SNR理解學習

    這篇文章主要介紹了C語言編程信噪比SNR計算的理解學習,信噪比,英文名稱叫做SNR或S/N(SIGNAL-NOISE RATIO)。是指一個電子設(shè)備或者電子系統(tǒng)中信號與噪聲的比例
    2021-10-10
  • C++中的自增與自減

    C++中的自增與自減

    這篇文章主要介紹了C++中的自增與自減,自增與自減是C++當中兩個使用頻率非常高的運算符,不僅在循環(huán)當中用到,在日常的代碼當中也經(jīng)常使用,下面來看看文章得具體介紹
    2021-11-11
  • 解讀C語言非void函數(shù)卻沒有return會怎么樣

    解讀C語言非void函數(shù)卻沒有return會怎么樣

    這篇文章主要介紹了解讀C語言非void函數(shù)卻沒有return會怎么樣的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • C++實現(xiàn)計算器功能

    C++實現(xiàn)計算器功能

    這篇文章主要為大家詳細介紹了C++實現(xiàn)計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C語言函數(shù)調(diào)用基礎(chǔ)應(yīng)用詳解

    C語言函數(shù)調(diào)用基礎(chǔ)應(yīng)用詳解

    函數(shù)就是一段封裝好的,可以重復使用的代碼,它使得我們的程序更加模塊化,不需要編寫大量重復的代碼。這篇文章主要介紹了c語言是如何處理函數(shù)調(diào)用的?需要的朋友可以參考下
    2023-02-02
  • C/C++中四種常用查找算法的實現(xiàn)

    C/C++中四種常用查找算法的實現(xiàn)

    C語言作為一種強大的編程語言,提供了多種搜索算法的實現(xiàn)方式,本文將介紹C語言中的四種常見搜索算法并提供每種算法的簡單實現(xiàn)示例,需要的小伙伴可以參考下
    2023-11-11
  • C++實現(xiàn)LeetCode(203.移除鏈表元素)

    C++實現(xiàn)LeetCode(203.移除鏈表元素)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(203.移除鏈表元素),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • QT實現(xiàn)貪吃蛇游戲

    QT實現(xiàn)貪吃蛇游戲

    這篇文章主要為大家詳細介紹了QT實現(xiàn)貪吃蛇游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • C/C++中如何判斷某一文件或目錄是否存在

    C/C++中如何判斷某一文件或目錄是否存在

    以下文章是對C/C++中判斷某一文件或目錄是否存在的實現(xiàn)代碼進行了詳細的分析介紹,需要的朋友可以參考下
    2013-07-07

最新評論