當前位置:首頁 » 編程語言 » c語言數組存儲方式
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言數組存儲方式

發布時間: 2022-02-25 01:25:01

A. c語言用數組存儲大型數據的演算法

/*
size_a,pa——指向數組a的有效末端
ma——a的最大容量,必須大於na

n=12——求n的階
p——求階乘時的當前乘數
*/
#include<stdio.h>
#define Ma 10000
int pa;/*指向數組a的有效末端*/
int p=2;
int memory_over=0;
union data
{ unsigned long int b;
struct
{unsigned l:16;
unsigned h:16;
}m;
}a[Ma];
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
演算法說明1:考慮到result比較長,我用a[Ma].b來存儲n!的result,每一位a[pa].b能存儲4位10進制數字。
因為我定義的數組是靜態的,所以Ma應該足夠大。
ps:其實只用定義一個unsigned long int b[Ma];就可以了(直接用b[pa]代替a[pa].b),但是我考慮到可能會訪問每一結點b[pa]的高16位(a[pa].m.h)和低16位(a[pa].m.l),但是的我考慮是多餘的!!不用像我這樣定義這么復雜的共用體!!
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
unsigned int cashe;
unsigned int carry;

void main()
{
unsigned int n;/*求n的階*/
void facto(unsigned int n);
printf("Input n:");
scanf("%u",&n);
/*=================開始求階乘!=============*/
a[0].b=1;/*初始化*/
facto(n);
/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
演算法說明2:上面這句直接調用facto(n)來求n!
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
/*========================以下是顯示最後結果====================================*/
if(memory_over==0)
{printf("the result include %dNO:\n",pa+1);
printf("%u",a[pa--].m.l);
for(;pa>=0;pa--)
printf("%04u",a[pa].m.l);
printf("\n");
}
getch();
}

/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
演算法說明2:求階函數facto(n)說明:
這個函數會不斷地調用multiple(),它的作用是每被調用一次就使得a[pa].b與階數p相乘一次,直到乘完n為止!
{multiple();
p++;/*每一輪乘一個階數p*/
}
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
void facto(unsigned int n)
{void multiple();
pa=0;
while(pa<Ma-1&&p<=n)/*容量限制*/
{multiple();
p++;/*每一輪乘一個階數p*/
}
if(p<=n)
{printf("memory out!\n");memory_over=1;}/*如果當前的存儲結果的數組a[Ma]不夠用!應提高Ma*/

}

/*==============================================================================
演算法說明3:乘法函數multiple()說明:負責a[pa].b與階數p相乘。
a[pa].b有很多結點,a[0].b、a[1].b、a[2].b、a[3].b、a[4].b、。。。
當然是從低結點a[0].b開始不斷與p相乘,產生的「進位」加到高位a[1].b,直到a[pa].b*p為止!

隨著結果數值增大,pa個結點的a[].b可能容納不下結果,所以如果a[pa].b與p相乘後還有「進位」carry,就擴大pa,並把carry放入到新增加的結點:
if(carry>0)
a[++pa].b=carry;
===================================================================================*/
void multiple()
{int i=0;
carry=0;
while(i<=pa)/*i指向當前處理的元素a[i],每一輪用一個位與階數p相乘*/
{a[i].b=a[i].b*p+carry;/*計算結果,要考慮來自低位的進位*/
carry=a[i].b/10000;/*計算進位*/
a[i].b=a[i].b%10000;/*計算余數*/
i++;
}
if(carry>0)
a[++pa].b=carry;
}

B. c語言數組存儲

你可知道char b[][100]={0};這是什麼意思嗎?當你不指定第二維的長度,初始化時又沒明確指出其長度,那麼編譯器就會把上式變為:char b[1][100]={0};結果你只開辟了1組100個char的數組,你還以為能有10組,當然錯誤啦。如果明確包含10個字元串,請明確指定:char b[10][100]={0};

你這個彈錯,意思就是你開辟的內存空間不夠,導致strcpy函數運行時緩沖區溢出,這使得程序跳轉到一個非法的區域,這個區域被操作系統標記為保護,於是觸發「CPU常規保護異常」。

以下僅作談資,騙分數用的^ ^。
我印象中,如果是「CPU常規保護異常」,可能意味著你這跳轉到的地方是操作系統內核區。當CPU以用戶許可權等級(最低許可權等級,你這個main函數執行時,printf函數執行前或執行後是就是這種狀態)嘗試跳轉到/訪問需要CPU最高特權等級的區域就會觸發這類錯誤。

C. C語言中如何用數組存放數

把這個數轉換為字元,以字元形式輸出。
或者直接sprint(a,long num )
,然後printf("%s",a),

D. c語言數組存儲形式是怎麼根據的如

c語言中沒有字元串的儲存形式像
string
arr;是c++中才出現的,c語言中的字元串是儲存在數組中的而且以'\0'為結束標志

E. C語言數組定義和存儲。

不會,除非桟區溢出,另外你這種定義的方法是有危險的,照你這種思路,甚至都能找到c[100][3],
這個對編譯器肯定是一種考驗,支持樓上的說法,是編譯器,我的觀點是,雖然c語言相對java c#不安全,但我們應該盡量將它處理安全

F. C語言數據文件有幾種存儲方式每種存儲形式各有什麼特點

一、auto auto稱為自動變數。 局部變數是指在函數內部說明的變數(有時也稱為自動變數)。用關鍵字auto進7行說明, 當auto省略時, 所有的非全程變數都被認為是局部變數, 所以auto實際上從來不用。 局部變數在函數調用時自動產生, 但不會自動初始化, 隨函數調用的結束, 這個變數也就自動消失了, 下次調用此函數時再自動產生, 還要再賦值, 退出時又自動消失。 二、static static稱為靜態變數。根據變數的類型可以分為靜態局部變數和靜態全程變數。 1. 靜態局部變數 它與局部變數的區別在於: 在函數退出時, 這個變數始終存在, 但不能被其它、函數使用, 當再次進入該函數時, 將保存上次的結果。其它與局部變數一樣。 2. 靜態全程變數 Turbo C2.0允許將大型程序分成若干獨立模塊文件分別編譯, 然後將所有模塊的目標文件連接在一起, 從而提高編譯速度, 同時也便於軟體的管理和維護。靜態全程變數就是指只在定義它的源文件中可見而在其它源文件中不可見的變數。它與全程變數的區別是: 全程變數可以再說明為外部變數(extern), 被其它源文件使用,而靜態全程變數卻不能再被說明為外部的, 即只能被所在的源文件使用。 三、extern extern稱為外部變數。為了使變數除了在定義它的源文件中可以使用外, 還要被其它文件使用。因此, 必須將全程變數通知每一個程序模塊文件, 此時可用extern來說明。 四、register register稱為寄存器變數。它只能用於整型和字元型變數。定義符register說明的變數被Turbo C2.0存儲在CPU的寄存器中, 而不是象普通的變數那樣存儲在內存中, 這樣可以提高運算速度。但是Turbo C2.0隻允許同時定義兩個寄存器變數,一旦超過兩個, 編譯程序會自動地將超過限制數目的寄存器變數當作非寄存器變數來處理。因此, 寄存器變數常用在同一變數名頻繁出現的地方。另外, 寄存器變數只適用於局部變數和函數的形式參數, 它屬於auto型變數,因此, 不能用作全程變數。定義一個整型寄存器變數可寫成: register int a;

G. C語言中數據(如字元型數據等)的存儲形式是什麼

C語言中的所有數據,都是以二進制方式存儲的。
事實上,在計算機中,只有二進制的數據,其它的所有形式,字元,8進制,10進制,或者16進制,都是給人看的。

對於計算機來說,作為一個電子產品,能夠識別的只有高低電平,開路閉路,所以實際上,在計算機中,無論是運算還是存儲,都只是0和1的序列。

H. C語言中數據的存儲方式是什麼

動態存儲方式和靜態存儲方式(按存儲時間分配的)
static聲明是靜態的,其他是動態的
int f1(int a)
{
static int b = 0;
return (a+b);
}

int f2(int a)
{
int b = 0;;
return (a+b);
}

int main()
{
printf("%d",f1(0));//0
printf("%d",f1(0));//1
printf("%d",f2(0));//0
printf("%d",f2(0));//0
return 0;
}

I. c語言問題:c語言中二維數組在內存中怎樣存儲

嚴格意義上說不存在二維數組,只是數組里的每個元素是一個一維數組,而內存是一段連續的空間,根據你申請一個變數的順序按地址從低到高排,所以二維數組不可能像一個矩陣那樣在內存中排列,這就涉及到它是按行依次往下排,還是按列往下排,而在c++中是按行,既 int a[2][2]
a[0][0]
a[0][1]
a[1][0]
a[1][1]