C語(yǔ)言中的一維數(shù)組與二維數(shù)組的實(shí)現(xiàn)
一維數(shù)組
數(shù)組的創(chuàng)建
數(shù)組是一組相同類型元素的集合。
int arr1[10]; char arr3[10]; float arr4[10]; double arr5[10];
下面這個(gè)數(shù)組能否成功創(chuàng)建?
int count = 10; int arr2[count];
**注:**在C99標(biāo)準(zhǔn)之前, [] 中要給一個(gè)常量才可以,不能使用變量。在C99標(biāo)準(zhǔn)支持了變長(zhǎng)數(shù)組的概念,數(shù)組的大小可以使用變量指定,但是數(shù)組不能初始化。不過(guò)在C90標(biāo)準(zhǔn)下仍然有一些不能實(shí)現(xiàn),所以具體能否實(shí)現(xiàn)還是要看編譯環(huán)境。
初始化
int arr1[10] = {1,2,3};
int arr2[] = {1,2,3,4};
int arr3[5] = {1,2,3,4,5};
char arr4[3] = {'a',98, 'c'};
char arr5[] = {'a','b','c'};
char arr6[] = "abcdef";
上述都是正確的數(shù)組初始化,數(shù)組在創(chuàng)建的時(shí)候如果想不指定數(shù)組的確定的大小就得初始化。數(shù)組的元素個(gè)數(shù)根據(jù)初始化的內(nèi)容來(lái)確定。
char arr1[] = "abc";
char arr2[3] = {'a','b','c'};
這兩行代碼都是給數(shù)組初始化為abc三個(gè)字符,但是在內(nèi)存中的分配是不一樣的。

使用
我們之前介紹了一個(gè)操作符: [] ,下標(biāo)引用操作符。它其實(shí)就數(shù)組訪問(wèn)的操作符。
#include <stdio.h>
int main()
{
int arr[10] = { 0 };//數(shù)組的不完全初始化
//計(jì)算數(shù)組的元素個(gè)數(shù)
int sz = sizeof(arr) / sizeof(arr[0]);
//對(duì)數(shù)組內(nèi)容賦值,數(shù)組是使用下標(biāo)來(lái)訪問(wèn)的,下標(biāo)從0開(kāi)始。所以:
int i = 0;//做下標(biāo)
for (i = 0; i < 10; i++)
{
arr[i] = i;
}
//輸出數(shù)組的內(nèi)容
for (i = 0; i < 10; ++i)
{
printf("%d ", arr[i]);
}
return 0;
}
注意:
- 數(shù)組是通過(guò)下標(biāo)來(lái)訪問(wèn)的,下標(biāo)是從0開(kāi)始。
- 數(shù)組的大小可以通過(guò)計(jì)算得到。
int arr[10]; int sz = sizeof(arr)/sizeof(arr[0]);
在內(nèi)存中的存儲(chǔ)
#include <stdio.h>
int main()
{
int arr[10] = {0};
int i = 0;
int sz = sizeof(arr)/sizeof(arr[0]);
for(i=0; i<sz; ++i)
{
printf("&arr[%d] = %p\n", i, &arr[i]);
}
return 0;
}
我們通過(guò)打印地址來(lái)觀察數(shù)組在內(nèi)存中的存吃是怎么樣的?

十六進(jìn)制是從0 ~ 9,A ~ F(相當(dāng)于10~15),觀察輸出的結(jié)果,可以發(fā)現(xiàn)當(dāng)下標(biāo)增長(zhǎng)1,元素的地址增加4,從低地址到高地址非常有規(guī)律地增加,數(shù)組在內(nèi)存中是連續(xù)存放的
二維數(shù)組
創(chuàng)建
int arr[3][4]; char arr[3][5]; double arr[2][4];
初始化
int arr[3][4] = {1,2,3,4};
int arr[3][4] = {{1,2},{4,5}};
int arr[][4] = {{2,3},{4,5}};
注意:二維數(shù)組如果有初始化,行可以省略,列不能省略。
int arr[][4] = {{2,3},{4,5}}; //正確寫(xiě)法
int arr[4][] = {{2,3},{4,5}}; //錯(cuò)誤寫(xiě)法使用
和一維數(shù)組一樣通過(guò)下標(biāo)訪問(wèn)。
#include <stdio.h>
int main()
{
int arr[3][4] = { 0 };
int i = 0;
for (i = 0; i < 3; i++)
{
int j = 0;
for (j = 0; j < 4; j++)
{
arr[i][j] = i * 4 + j;
}
}
for (i = 0; i < 3; i++)
{
int j = 0;
for (j = 0; j < 4; j++)
{
printf("%d\t", arr[i][j]); //為了好看加制表符并換兩行
}
printf("\n\n");
}
return 0;
}
在內(nèi)存中的存儲(chǔ)
#include <stdio.h>
int main()
{
int arr[3][4];
int i = 0;
for (i = 0; i < 3; i++)
{
int j = 0;
for (j = 0; j < 4; j++)
{
printf("&arr[%d][%d] = %p\n\n", i, j, &arr[i][j]);
}
}
return 0;
}

通過(guò)觀察我們發(fā)現(xiàn)二維數(shù)組在內(nèi)存中也是從低地址到高地址連續(xù)存儲(chǔ)的。
數(shù)組越界
數(shù)組的下標(biāo)是有范圍限制的。
數(shù)組的下規(guī)定是從0開(kāi)始的,如果數(shù)組有n個(gè)元素,最后一個(gè)元素的下標(biāo)就是n-1。
所以數(shù)組的下標(biāo)如果小于0,或者大于n-1,就是數(shù)組越界訪問(wèn)了,超出了數(shù)組合法空間的訪問(wèn)。
C語(yǔ)言本身是不做數(shù)組下標(biāo)的越界檢查,編譯器也不一定報(bào)錯(cuò),但是編譯器不報(bào)錯(cuò),并不意味著程序就是正確的,所以程序員寫(xiě)代碼時(shí),最好自己做越界的檢查。
#include <stdio.h>
int main()
{
int arr[10] = {1,2,3,4,5,6,7,8,9,10};
int i = 0;
for(i=0; i<=10; i++)
{
printf("%d\n", arr[i]);//當(dāng)i等于10的時(shí)候,越界訪問(wèn)了
}
return 0;
}

二維數(shù)組也存在行或列可能越界的問(wèn)題。
到此這篇關(guān)于C語(yǔ)言中的一維數(shù)組與二維數(shù)組的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)C語(yǔ)言一維數(shù)組與二維數(shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ sdl實(shí)現(xiàn)渲染旋轉(zhuǎn)視頻的方法分享
一般情況下播放視頻時(shí)不需要旋轉(zhuǎn),但是如果是移動(dòng)端錄制的視頻有時(shí)會(huì)出現(xiàn)rotate參數(shù),且視頻寬高也是互換的。所以本文為大家準(zhǔn)備了利用sdl實(shí)現(xiàn)渲染旋轉(zhuǎn)視頻的方法,需要的可以參考一下2022-12-12
實(shí)例講解C++設(shè)計(jì)模式編程中State狀態(tài)模式的運(yùn)用場(chǎng)景
這篇文章主要介紹了實(shí)例講解C++設(shè)計(jì)模式編程中State狀態(tài)模式的運(yùn)用場(chǎng)景,文章最后的適用性部分則介紹了一些State模式善于處理的情況,需要的朋友可以參考下2016-03-03
C++ Primer 標(biāo)準(zhǔn)庫(kù)vector示例詳解
該文章主要介紹了C++標(biāo)準(zhǔn)庫(kù)中的vector類型,包括其定義、初始化、成員函數(shù)以及常見(jiàn)操作,文章詳細(xì)解釋了如何使用vector來(lái)存儲(chǔ)和操作對(duì)象集合,并提供了代碼示例來(lái)說(shuō)明vector的使用方法,感興趣的朋友一起看看吧2025-03-03

