005__数组.初阶

[ 基本难度系数 ]:★★★☆☆

一、基本概念

  • 逻辑:一次性定义多个相同类型的变量,并存储到一片连续的内存中
  • 示例:
int num[5];
  1. 语法释义:
    1. num 是数组名,即这片连续内存的名称
    2. [5] 代表这片连续内存总共分成5个相等的格子,每个格子称为数组的元素
    3. int 代表每个元素的类型,可以是任意基本类型,也可以是组合类型,甚至可以是数组
  1. 初始化:在定义的时候赋值,称为初始化
int num[5] = {100,200,300,400,500};        // ok,正常初始化
int num[5] = {100,200,300,400,500,600};     // 错误,越界了
int num[ ] = {100,200,300};                 // OK,自动根据初始化列表分配数组元素个数
int num[5] = {100,200,300};                 // OK,只初始化数组元素的一部分

解析:

二、数组元素的赋值和引用

  • 存储模式:一片连续的内存,按数据类型分割成若干相同大小的格子
  • 元素下标:数组开头位置的偏移量,a[0]引用第1个格子,a[1]引用第2个格子,以此类推

元素下标偏移量

示例代码:

#include <stdio.h>
// 计算数组元素个数 == 
#define CAL_ARR_NUM(A) ( sizeof(A)/sizeof(A[0]) )
                       // 整个数组的大小/数组一个元素的大小

int main(int argc, char const *argv[])
{
    // 初始化
    int  ibuf[5] = {1,2,3,4,5}; // int型数组的12345和char型数组(字符串)的"12345"是不一样
    char sbuf[5] = {"1234"};

    // (1)、单个赋值
    ibuf[0] = 100;
    ibuf[1] = 200;
    ibuf[2] = 300;
    ibuf[3] = 400;
    ibuf[4] = 500;
    // ibuf[5] = 600;   // 到此为止,后面的内存是非法区域(也就你没有权限对其更改) 
    
    // (2)、循环赋值
    long unsigned int ret = CAL_ARR_NUM(ibuf);
    printf("数组的元素个数为 = %lu\n", ret);

    for (int i = 0; i < ret; i++)
    {
        ibuf[i] = (i+1)*100;
        printf("buf[%d] = %d\n", i, ibuf[i]);
    }


    return 0;
}

三、其它类型的数组

(1)、字符数组

  • 概念:专门存放字符的数组,称为字符数组
  • 初始化与元素引用:
  • 示例代码:
#include <stdio.h>
#include <string.h>
#include <strings.h>

// 计算数组元素个数 ==        
#define CAL_ARR_NUM(A) ( sizeof(A)/sizeof(A[0]) )
                       // 整个数组的大小/数组一个元素的大小

int main(int argc, char const *argv[])
{
    // (1)、字符数组
    // 1、字符串数组初始化
    char s1[5] = {'a', 'b', 'c', 'd', 'e'};    // 字符数组,不是字符串(末尾没有'\0')
    char s2[5] = {'a', '
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值