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

C語言數(shù)組快速入門詳細(xì)講解

 更新時(shí)間:2022年05月12日 14:37:44   作者:珠江上  
數(shù)組是一組有序的數(shù)據(jù)的集合,數(shù)組中元素類型相同,由數(shù)組名和下標(biāo)唯一地確定,數(shù)組中數(shù)據(jù)不僅數(shù)據(jù)類型相同,而且在計(jì)算機(jī)內(nèi)存里連續(xù)存放,地址編號(hào)最低的存儲(chǔ)單元存放數(shù)組的起始元素,地址編號(hào)最高的存儲(chǔ)單元存放數(shù)組的最后一個(gè)元素

1.一維數(shù)組

數(shù)組的定義: 數(shù)組是一組相同類型元素的集合

a.一維數(shù)組的創(chuàng)建

數(shù)組的創(chuàng)建格式為: 數(shù)組的類型 數(shù)組名[ 常量表達(dá)式] ;

關(guān)于數(shù)組創(chuàng)建易錯(cuò)點(diǎn):

b.一維數(shù)組的初始化

類似于給整型變量初始化的過程:

int a=2; int b=5; int c=66;

關(guān)于數(shù)組初始化易錯(cuò)點(diǎn):

字符串的結(jié)束標(biāo)志是 \0

特別注意:數(shù)組長(zhǎng)度和字符串長(zhǎng)度不是一個(gè)東西

#include <stdio.h>
#include <string.h>
int main()
{
	int arr1[3] = { 1,2,3 };
	//數(shù)組有1、2、3這三個(gè)元素
	int arr2[4] = { 1,2,3 };
	//數(shù)組有1、2、3、0這四個(gè)元素
	int arr3[4] = { 0 };
	//數(shù)組有0、0、0、0這四個(gè)元素
	char ch4[5] = "dat";
	//數(shù)組有d、a、t、\0、0這五個(gè)元素
	char ch5[] = "dat";
	//數(shù)組有d、a、t、\0這四個(gè)元素
	char arr6[] = "abc";
	//數(shù)組有a、b、c、\0四個(gè)元素,該數(shù)組長(zhǎng)度為3,字符串長(zhǎng)度為3
	char arr7[] = {'a','b','c'};
	//數(shù)組有a、b、c三個(gè)元素,該數(shù)組長(zhǎng)度為3,字符串長(zhǎng)度為隨機(jī)值
	printf("%d\n", strlen(arr6));//3
	printf("%d\n", strlen(arr7));//隨機(jī)值
	printf("%s\n", arr6);//得abc
	printf("%s\n", arr7);//abc亂七八糟
	return 0;
}

c.一維數(shù)組的使用

訪問數(shù)組中的某個(gè)元素用到[ ]下標(biāo)引用操作符, 數(shù)組是使用下標(biāo)來訪問的,下標(biāo)是從0開始

計(jì)算數(shù)組的大小如下代碼:

#include <stdio.h>
int main()
{
    int arr[10] = {0};
    int sz = sizeof(arr) / sizeof(arr[0]);
    printf("則數(shù)組的大小為%d\n",sz);
    return 0;
}

d.一維數(shù)組在內(nèi)存中的存儲(chǔ)

一維數(shù)組在內(nèi)存中連續(xù)存放

數(shù)組的存放地址由低到高變化,看代碼:

2.二維數(shù)組

一維數(shù)組長(zhǎng)這樣:

int arr [ 10 ]= { 0 } ;

二維數(shù)組長(zhǎng)這樣:

int arr [ 3] [4 ]= { {1,2}, {3,4}} ;

a.二維數(shù)組的創(chuàng)建

int arr1 [ 3 ] [ 4 ] ; 三行四列

char arr2 [ 4] [ 4 ] ; 四行四列

float arr3 [ 3 ] [ 6] ; 三行六列

特別注意:二維數(shù)組中,行可以省略,如:

int arr [ ] [ 4 ] ;

b.二維數(shù)組的初始化

int arr1 [ 3 ] [ 4 ] = {1,2,3,4,5};

第一行: 1 2 3 4

第二行: 5 0 0 0

第三行: 0 0 0 0

char arr2 [ 4] [ 4 ] ={ {1,2} , {3,4} } ;

第一行: 1 2 0 0

第二行: 3 4 0 0

第三行: 0 0 0 0

第四行: 0 0 0 0

float arr3 [ 3 ] [ 6] = { {1,2} , {3,4} , {5,6,0,2} } ;

第一行: 1 2 0 0 0 0

第二行: 3 4 0 0 0 0

第三行: 5 6 0 2 0 0

特別注意:未完全初始化的部分都是0

c.二維數(shù)組的使用

和一維數(shù)組相同,二維數(shù)組的使用也是通過下標(biāo)的方式實(shí)現(xiàn), 行和列的順序,以及下標(biāo)的的順序不能錯(cuò)哦

d.二維數(shù)組在內(nèi)存中的存儲(chǔ)

通過下圖,我們發(fā)現(xiàn):

二維數(shù)組在內(nèi)存中也是連續(xù)存儲(chǔ)的

數(shù)組的存放地址也是由低到高變化

3.數(shù)組越界

數(shù)組的下標(biāo)是有限制的

規(guī)定:數(shù)組下標(biāo)從0開始,最后一個(gè)元素下標(biāo)為n-1

看以下代碼:

i=3;則有0 1 2 3 四個(gè)下標(biāo)就有四個(gè)元素,

j=4;則有0 1 2 3 4 五個(gè)下標(biāo)就有五個(gè)元素

4.數(shù)組作為函數(shù)參數(shù)

這里用個(gè)冒泡函數(shù):將元素排序,來舉例

這個(gè)代碼通過調(diào)試,才能得出效果

#include <stdio.h>
 
void bubble_sort(int arr[], int sz)
{
    int i = 0;
    for (i = 0; i < sz - 1; i++)
    {
        int j = 0;
        for (j = 0; j < sz - i - 1; j++)
        {
            if (arr[j] > arr[i])
            {
                int tmp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = tmp;
            }
        }
    }
}
int main()
{
    int arr[] = { 1,3,6,8,2,9 };
    int sz = sizeof(arr) / sizeof(arr[0]);
    bubble_sort(arr, sz);
    return 0;
}

5.數(shù)組名

數(shù)組名就是首元素的地址(倆個(gè)例外)

1.sizeof(數(shù)組名)計(jì)算的是數(shù)組的大小

2.&數(shù)組名,取出的是數(shù)組的地址

到此這篇關(guān)于C語言數(shù)組快速入門詳細(xì)講解的文章就介紹到這了,更多相關(guān)C語言數(shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論