C语言学习之数组(1)

本文详细介绍了C语言中一维和二维数组的创建、初始化方法,包括数组的定义、不完全初始化及使用下标访问元素。同时,探讨了数组在内存中的存储方式,通过示例展示了数组元素的内存地址。此外,还讲解了二维数组的行数和列数定义,以及初始化和使用方法,最后讨论了二维数组在内存中的连续存储特性。
摘要由CSDN通过智能技术生成

一维数组的创建与初始化

数组是一组相同类型元素的集合。

数组的创建方式:

type_t   arr_name   [const_n];
//type_t 是指数组的元素类型
//const_n 是一个常量表达式,用来指定数组的大小

数组创建举例

//代码1
int arr1[10];
//代码2
int count = 10;
int arr2[count];//数组时候可以正常创建?
//代码3
char arr3[10];
float arr4[1];
double arr5[20];

注意:数组创建,[]中必须是常量,不能使用变量。

数组的初始化

数组在创建的时候如果想不指定数组的确定的大小就得初始化。数组的元素个数根据初始化的内容来确定。

int arr1[10] = {1,2,3};//不完全初始化,剩下的元素默认初始化为0
int arr2[] = {1,2,3,4};
int arr3[5] = {12345}char arr4[3] = {'a',98, 'c'};
char arr5[] = {'a','b','c'};
char arr6[] = "abcdef";

但对于下面的两种代码要区分

char arr1[] = "abc";
char arr2[3] = {'a','b','c'};

一维数组的使用

下标引用操作符 [] 。它其实就是数组访问的操作符。数组使用下标访问,下标从0开始,并且数组的大小可以通过计算得到。

#include <stdio.h>
int main()
{
    int arr[10] = {0};//数组的不完全初始化
    //计算数组的元素个数
    int sz = sizeof(arr)/sizeof(arr[0]);
    //对数组内容赋值,数组是使用下标来访问的,下标从0开始。所以:
    int i = 0;//做下标
    for(i=0; i<10; i++)//这里写10,好不好?
    {
        arr[i] = i;
    }   
    //输出数组的内容
    for(i=0; i<10; ++i)
    {
        printf("%d ", arr[i]);
    }
    return 0;
}

一维数组在内存中的存储

数组在内存中是连续存放的。

#include <stdio.h>
int main()
{
    int arr[10] = {0};
    int i = 0;
    for(i=0; i<sizeof(arr)/sizeof(arr[0]); ++i)
    {
        printf("&arr[%d] = %p\n", i, &arr[i]);
    }
    return 0;
}

运行结果如下:
在这里插入图片描述

二维数组的创建于初始化

二维数组的创建

第一个[]是行数,第二个[]是列数。行和列的下标不能同时没有。

//数组创建
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}};//{1,2}放在第一行,{4,5}放在第二行
int arr[][4] = {{2,3},{4,5}};

二维数组的使用

二维数组的使用也是通过下标实现。

#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 ", arr[i][j]);
        }
    }
    return 0;
}

二维数组在内存中的存储

二维数组在内存中也是连续存在的

#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", i, j,&arr[i][j]);
        }
    }
    return 0;
}

运行结果如下:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值