标准C语言03

本文详细介绍了C语言中数组的基本概念,包括一维数组的定义、使用、初始化以及数组越界问题。同时,深入探讨了二维数组的构造及其遍历方法,并特别讲解了变长数组的特点与注意事项。通过实例演示如何定义并操作数组,以及如何找出二维数组中的最小值坐标和周边数值求和。
摘要由CSDN通过智能技术生成

标准C语言

数组

什么是数组:变量的组合,是一种批量定义类型相同变量的方式

定义: 类型名 数组名[数量];

​ int sum_arr[5];

**使用:**数组名[下标];

​ 下标:从0开始 范围:0~数量-1

**遍历:**与for循环配合使用,使用循环变量当做数组的下标

**初始化:**类型名 数组名[数量] = {1,2,3,4…};

​ 1、因为数组的值默认是随机的,一般为了安全起见,要对数组进行初始化

​ 2、初始化的数据过多,编译器会产生警告并丢弃多余的数据

​ 3、初始化的数据不够,编译器会末尾补0

​ 4、初始化时数据可以省略,只写大括号,相当于给所有成员初始化为0

​ 5、这种初始化语法只能在定义数组时使用,并且只能逐个赋值,不能整体赋值(int arr[5] = 1错误)

​ 6、初始化时数组的数量可以省略,编译器会自动统计初始化中数据的个数,并告诉数组确定数组的

​ 数量,一旦数组的数量确定,后面无法改变

​ 7、 sizeof(arr)/sizeof(arr[0]) = 数组的个数

​ sizeof(arr) == 数组的总字节数

​ sizeof(arr[0]) == 数组单个成员的字节数

数组越界

为了程序的编译、运行效率,编译器不去检查数组的下标

数组越界的后果:

​ 1、段错误(核心已转储)

​ 2、一切正常

​ 3、脏数据

在使用数组过程中,要时刻注意不要越界

二维数组

一维数组相当于把变量排成一排,通过编号访问

二维数组相当于把变量排成一个矩阵,通过行号和列号访问

**定义:**类型 数组名[行数] [列数]

  int arr[3][5];
       
[0,0][0,1][0,2][0,3][0,4]
[1,0][1,1][1,2][1,3][1,4]
[2,0][2,1][2,2][2,3][2,4]

**使用:**数组名[行下标] [列下标];

​ 行下标:0~行数-1

​ 列下标:0~列数-1

**遍历:**需要与双层for循环配合,一般外层循环负责遍历行,内层循环负责遍历列。

   int arr[3][5];

    for(int i=0;i<3;i++)

   {

     for(int j=0;j<5;j++)

     {
       	printf("%d ",arr[i][j]);
     }

      printf("\n");

   }

初始化:类型 数组名[行数][列数]={{第一行},{第二行},{第三行},…};

变长数组

定义数组时使用变量作为数组的长度,在代码编译期间数组的长度是不确定的,当

运行到数组的定义语句时数组的长度才最终确定下来,这种数组称为变长数组

注意:长度一旦确定,后面都无法改变

优点:可以根据实际情况来确定数组的长度,以此节约内存空间

缺点:不能进行初始化,因为初始化发生在程序编译期间

例题

作业1:定义一个5*5的二维数组并初始化,找出最小值的坐标,计算出最小值周围一圈数据之和

​ 4 2 4 6 5

​ 4 2 3 2 1

​ 4 2 0 5 6

​ 1 2 3 4 5

​ 1 2 3 4 5

#include <stdio.h>

int main(int argc,const char* argv[])
{
    int arr[5][5]=
    {   
        {1,1,1,1,0},
        {1,1,1,1,1},
        {1,1,1,1,1},
        {1,1,1,1,1},
        {1,1,1,1,1}
    };  
    int min=arr[0][0];
    int h=0,l=0;
    int sum=0;
    for(int i=0;i<5;i++)
    {   
        for(int j=0;j<5;j++)
        {
            if(arr[i][j]<min)   
            {
                min = arr[i][j];    
                h=i;
                l=j;
            }
        }
    }   
    if(h-1>=0)
    {   
        sum+=arr[h-1][l];
        if(l-1>=0)
            sum+=arr[h-1][l-1];
        if(l+1<=4)
            sum+=arr[h-1][l+1];
    }   
	if(h+1<=4)
    {
        sum+=arr[h+1][l];
        if(l-1>=0)
            sum+=arr[h+1][l-1];
        if(l+1<=4)
            sum+=arr[h+1][l+1];
    }
    if(l+1<=4)
        sum+=arr[h][l+1];
    if(l-1>=0)
        sum+=arr[h][l-1];
    printf("%d",sum);

作业2:输入N,显示N层杨辉三角

1

1 1

1 2 1

1 3 3 1

1 4 6 4 1

1 5 10 10 5 1

#include <stdio.h>

int main(int argc,const char* argv[])
{
    int N;
    printf("请输入杨辉三角的阶数:");
    scanf("%d",&N);
    int arr[N][N];
    arr[0][0]=1;
    for(int i=1;i<N;i++)
    {   
        arr[0][i]=0;    
    }   
    for(int i=1;i<N;i++)
    {   
        arr[i][0]=1;    
    }   
    for(int i=1;i<N;i++)
    {   
        for(int j=1;j<N;j++)
        {
            arr[i][j]=arr[i-1][j]+arr[i-1][j-1];    
        }

    }   
    for(int i=0;i<N;i++)
    {   
        for(int j=0;j<N;j++)
        {
            if(0!=arr[i][j])
                printf("%d ",arr[i][j]);
        }
        printf("\n");
    }   
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值