数组的基础语法及代码示例

目录

1.什么是数组

2.一维数组

3.一维数组存放空间示意图

4.一维数组的初始化

5.一维数组经典例题 --斐波那契数列

6.二维数组

7.二维数组的初始化

8.二维数组例题 --找出矩阵最大值和最小值所在位置


1.什么是数组

  • 是一组相同类型的数据的有序集合。
  • 数组中的元素在内存中都是连续存放,每个元素都属于同一种数据类型数组中的
  • 数组中的数据数据按照一定的顺序排列存放

2.一维数组

  • 定义:类型名 数组名  [数组长度]
  • int a [10]    //int为数据类型  a为数组名称 10代表有多少元素
  • 上面为定义一个整数型一维数组,其他数据类型的数组定义只需要变换数据类型
  • eg : 浮点型 float ,字符型 char
  • 数组名是一个地址常量,存放数组内存空间的首地址

3.一维数组存放空间示意图

  •  int a[10] 

  •  图中a[0]的地址1064就是数组a的首地址
  • 由于int 整数型占2个字节即 数组a[10]总共申请了20个字节

 注意:引用数组时,只能引用单一数组,而不能引用整个数组

4.一维数组的初始化

  • 格式:类型名 数组名 [数组长度] = {初值表}
  • 注意:初值表可以为整个数值赋初始值,也可以只赋值部分值
  • int a[5] = {1,2,3,4,5}     //给数组全部元素赋值
    
    int b[5] = {1,2}    //给部分元素赋值,未赋值的默认值为0,即b[2] == 0,不分静态跟动态
  • 在C语言中有静态数组和动态数组,我们见到的经常为动态数组,值是可以改变的,而静态数组初始化后值不可改变
  • 静态数组写法:
  • static a [4] = {1,2,3,4}
  • 数组中如果对全部进行初始化赋值,则可以不写数组长度,根据的赋值数量来判断数组长度

5.一维数组经典例题 --斐波那契数列

  • 题目描述:  利用数组计算斐波那契数列的前10项,即1, 1, 2, 3, 5,...,55 ,并按每行打印5个数的格  式输出
  • 题目分析:  先求出斐波那契数列的前10项的值,可以定义函数或者递归两种方法
  • 代码如下
  • #include <stdio.h>
    int main()
    {
        int fib[10] = {1, 1}, i; //对数组进行赋值
        for (i = 2; i < 10; i++)
        {
    
            fib[i] = fib[i - 1] + fib[i - 2]; //讲求得值存入数组
        }
        for (i = 0; i < 10; i++)
        {
            printf("%6d", fib[i]);
            if ((i + 1) % 5 == 0)
                printf("\n");
        }
        return 0;
    }

6.二维数组

  • 定义形式: 类型名 数组名 [行长度] [列长度]
  • //定义一个二维数组,3行,3列,总共9个元素
    
    int a [3] [3] ;
  • 引用:跟一维数组一样,试用下标的方法进行引用
  • 引用格式: 数组名 [行下标] [列下标]

7.二维数组的初始化

  • 分行赋初值:
  • 一般形式: 类型名 数组名 [行长度] [列长度] = {{初值表0},…,{初值表k},...}
  • int a [3] [3] = {{1,2,3},{4,5,6},{7,8,9}}
  • 顺序赋初值:
  • 一般形式: 类型名 数组名 [行长度] [列长度] = {初值表}
  • int a [3] [3] = {1,2,3,4,5,6,7,7,9}
  •  如果只对部分元素赋初值,则要按顺序写,并且对不赋值的要补全0
  • int a [3] [3] = {1,2,3,4,0,0,0,6,7}

8.二维数组例题 --找出矩阵最大值和最小值所在位置

  • 题目描述:将1个3 x 2 得矩阵存入一个3 x 2得二维数组中,找出最大值以及它的行下标和列下标,并输出该矩阵
  • 题目分析: 这道题关键在于用假设法,去给最大值赋值,遍历数组所有元素进行比较,最后得出结果
  • 完整代码:
  • #include <stdio.h>
    int main()
    {
        int col, row, i, j;
        int a[3][2];
        //将输入的数据存入二维数组
        for (i = 0; i < 3; i++)
            for (j = 0; j < 2; j++)
                scanf("%d", &a[i][j]);
    
        //按矩阵的形式输出二维数组
        for (i = 0; i < 3; i++)
        {
            for (j = 0; j < 2; j++)
                printf("%4d", a[i][j]);
            printf("\n");
        }
        //遍历二维数组,找出最大值 a [row] [col]
        row = col = 0;      //先假设 a [0] [0]是最大值
        for (i = 0; i < 3; i++)
            for (j = 0; j < 2; j++)
                if (a[i][j] > a[row][col])      //如果 a [i] [j] 比假设值大
                {
                    row = i;    //再假设 a [i] [j] 是新的最大值
                    col = j;
                }
        printf("max = a [%d] [%d] = %d\n", row, col, a[row][col]);
        return 0;
    }
    

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
以下是使用最基础语法的汇编语言将数组 x 复制到数组 Y 的示例代码,假设数组 x 和数组 Y 的长度都为 5,数组元素的大小为一个字节。 ``` DATA SEGMENT X DB 1, 2, 3, 4, 5 Y DB 5 DUP (0) DATA ENDS CODE SEGMENT ASSUME CS:CODE, DS:DATA START: MOV AX, DATA MOV DS, AX MOV CX, 5 ; 循环次数 MOV SI, 0 ; 源数组 X 的偏移地址 MOV DI, 0 ; 目标数组 Y 的偏移地址 COPY_LOOP: MOV AL, X[SI] ; 从源数组 X 中读取一个字节 MOV Y[DI], AL ; 将该字节写入目标数组 Y INC SI ; 指向源数组的下一个字节 INC DI ; 指向目标数组的下一个字节 DEC CX ; 循环计数器减 1 JNZ COPY_LOOP ; 如果循环计数器不为 0,则跳转到 COPY_LOOP 标签处继续循环 MOV AH, 4CH ; 指令码,表示退出程序 INT 21H ; 调用 DOS 中断 CODE ENDS END START ``` 在上面的示例代码中,使用了 `MOV` 指令将数据段的首地址加载到 `DS` 寄存器中,然后使用 `MOV` 指令将循环次数、源数组 `X` 的偏移地址和目标数组 `Y` 的偏移地址分别加载到 `CX`、`SI` 和 `DI` 寄存器中。在循环中,使用 `MOV` 指令将源数组 `X` 中的一个字节读入 `AL` 寄存器,再使用 `MOV` 指令将 `AL` 寄存器中的值写入目标数组 `Y` 中。然后,使用 `INC` 指令将 `SI` 和 `DI` 分别指向源数组和目标数组中的下一个字节,再使用 `DEC` 指令将循环计数器减 1,最后使用 `JNZ` 指令判断循环计数器是否为 0,如果不为 0,则跳转到 `COPY_LOOP` 标签处继续循环。程序最后使用 DOS 中断 21H 的功能码 4CH 表示退出程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一树樱花白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值