首页 > 其他分享 >C语言之数组详解

C语言之数组详解

时间:2023-10-03 23:31:37浏览次数:45  
标签:初始化 10 int 元素 C语言 char 详解 数组


2.1 数组的概念

数组是若干个相同类型的变量在内存中有序存储的集合。

int a[10];//定义了一个整型的数组 a,a 是数组的名字,数组中有 10 个元素,每个元素的类型 都是 int 类型,而且在内存中连续存储。

这十个元素分别是 a[0] a[1] …. a[9] a[0]~a[9]

在内存中连续的顺序存储

2.2 数组的分类

2.2.1 按元素的类型分类

(1)字符数组

即若干个字符变量的集合,数组中的每个元素都是字符型的变量

char s[10]; s[0],s[1]....s[9];

(2)短整型的数组

short int a[10]; a[0] ,a[9]; a[0]=4;a[9]=8;

(3)整型的数组

int a[10]; a[0] a[9]; a[0]=3;a[0]=6;

(4) 长整型的数组

lont int a[5];

(5)浮点型的数组(单、双)

float a[6]; a[4]=3.14f;

double a[8];

a[7]=3.115926;

(6)指针数组

char *a[10] int *a[10];

(7)结构体数组 struct stu boy[10];

2.2.2 按维数分类

一维数组

int a[30];

类似于一排平房

二维数组

int a[2] [30];

可以看成一栋楼房 有多层,每层有多个房间,也类似于数学中的矩阵 二维数组可以看成由多个一维数组构成的。 有行,有列,

多维数组 int a[4] [2] [10];

三维数组是由多个相同的二维数组构成的

int a[5] [4] [2] [10];

2.3 数组的定义

定义一个数组,在内存里分配空间

2.3.1 一维数组的定义

格式:

数据类型 数组名 [数组元素个数];

int a [10]; char b [5];

定义了 5 个 char 类型变量的数组 b

5 个变量分别为 b[0] ,b[1],b[2],b[3],b[4];

在数组定义的时候可以不给出数组元素的个数,根据初始化的个数来定数组的大小

例 1:
#include <stdio.h>
int main(int argc, char *argv[])
{
int a[]={1,2,3,4,5};
printf("%d\n",sizeof(a));
return 0;
}

C语言之数组详解_数组

2.3.2 二维数组的定义

格式: 数据类型 数组名 [行的个数] [列的个数];

int a [4] [5];

定义了 20 个 int 类型的变量 分别是

a[0] [0] ,a[0] [1],a[0] [2] ,a[0] [3] ,a[0] [4];

a[1] [0] ,a[1] [1],a[1] [2] ,a[1] [3] ,a[1] [4];

a[2] [0] ,a[2] [1],a[2] [2] ,a[2] [3] ,a[2] [4];

a[3] [0] ,a[3] [1],a[3] [2] ,a[3] [3] ,a[3] [4];

多维数组定义:

int a[3] [4] [5]

int a[8] [3] [4] [5];

扩展: 二维数组在定义的时候,可以不给出行数,但必须给出列数,二维数组的大小根据初始化的行数来定

例 2:
#include <stdio.h>
int main(int argc, char *argv[])
{
int a[][3]={
{1,2,3}, {4,5,6}, {7,8,9}, {10,11,12}
};
printf("%d\n",sizeof(a));
return 0;
}

C语言之数组详解_数组_02

2.4 数组的初始化

定义数组的时候,顺便给数组的元素赋初值,即开辟空间的同时并且给数组元素赋值

2.4.1 一维数组的初始化

a、全部初始化 int a[5]={2,4,7,8,5}; 代表的意思: a[0]=2; a[1]=4;a[2]=7;a[3] = 8;a[4]=5;

b、部分初始化 int a[5]={2,4,3};初始化赋值不够后面补 0 a[0] = 2; a[1]= 4;a[2]=3;a[3]=0;a[4]=0;

注意:只能省略后面元素,可以不初始化,不能中间的不初始化

例 3:
#include <stdio.h>
int main(int argc, char *argv[]
{
int a[5]={2,3,5};
int i;
for(i=0;i<5;i++)
{
printf("a[%d]=%d\n",i,a[i]);
}
return 0;
}

C语言之数组详解_数组_03

2.4.2 二维数组的定义并初始化

按行初始化:

a、全部初始化

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

a[0] [0] =1; a[0] [1] = 2;

a[1] [0] = 4,a[1] [1]=5;

b、部分初始化

int a[3] [3]={{1,2},{1}};

a[0] [0] = 1;a[0] [2] =0;

逐个初始化:

全部初始化: int a [2] [3]={2,5,4,2,3,4};

部分初始化: int a[2] [3]={3,5,6,8};

2.5 数组元素的引用方法

2.5.1 一维数组元素的引用方法

数组名 [下标];//下标代表数组元素在数组中的位置

int a[5]; a[0] a[1] a[2] a[3] a[4];

2.5.2 二维数组元素的引用方法

数组名[行下标] [列下标];

int a [4] [5];

a[0] [0] ,a[0] [1],a[0] [2] ,a[0] [3] ,a[0] [4];

a[1] [0] ,a[1] [1],a[1] [2] ,a[1] [3] ,a[1] [4];

a[2] [0] ,a[2] [1],a[2] [2] ,a[2] [3] ,a[2] [4];

a[3] [0] ,a[3] [1],a[3] [2] ,a[3] [3] ,a[3] [4];

例 4:
#include <stdio.h>
int main(int argc, char *argv[])
{
int a[3][4]={{1,2,3,4},{5,6},{5}};
int b[3][4]={11,12,13,14,15,16,17,18,19};
int i,j;
for(i=0;i<3;i++)//遍历所有行
{
for(j=0;j<4;j++)//遍历一行的所有列
{
printf("a[%d][%d]=%d ",i,j,a[i][j]);
}
printf("\n");
}
for(i=0;i<3;i++)//遍历所有行
{
for(j=0;j<4;j++)//遍历一行的所有列
{
printf("b[%d][%d]=%d ",i,j,b[i][j]);
}
printf("\n");
}
return 0;}

C语言之数组详解_数组_04

2.5.3 字符数组

char c1[] ={‘c’,’ ’,’p’,’r’,’o’,’g’};

char c2[] = “c prog”;

char a = { {‘B’,’A’,’S’,’I’,’C’}, {‘d’,’B’,’A’,’S’,’E’} };

char a = {“hello”,“world”};

字符数组的引用

1.用字符串方式赋值比用字符逐个赋值要多占 1 个字节,用于存放字符串结束标志‘\0’

2.上面的数组 c2 在内存中的实际存放情况为:

C语言之数组详解_初始化_05

C语言之数组详解_初始化_06编辑

注:'\0'是由 C 编译系统自< /> 动加上的 3.由于采用了'\0'标志,字符数组的输入输出将 变得简单方便.


标签:初始化,10,int,元素,C语言,char,详解,数组
From: https://blog.51cto.com/u_16265376/7696163

相关文章

  • 力扣---189. 轮转数组
    给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。 示例1:输入:nums=[1,2,3,4,5,6,7],k=3输出:[5,6,7,1,2,3,4]解释:向右轮转1步:[7,1,2,3,4,5,6]向右轮转2步:[6,7,1,2,3,4,5]向右轮转3步:[5,6,7,1,2,3,4]示例 2:输入:nu......
  • 数组动态创建问题
    数组动态创建问题C++较新版本中允许通过变量方式动态创建数组intn;cin>>n;inta[n]={0};但有些ide会提示"表达式必须含有常量值c/c++"问题,可用一下方式消除此问题intn;cin>>n;inta*=newint[n];......
  • 第04章 NumPy基础:数组和矢量计算
    NumPy(NumericalPython的简称)是Python数值计算最重要的基础包。大多数提供科学计算的包都是用NumPy的数组作为构建基础。NumPy的部分功能如下:ndarray,一个具有矢量算术运算和复杂广播能力的快速且节省空间的多维数组。用于对整组数据进行快速运算的标准数学函数(无需编写循环)。......
  • 高级数据结构--树状数组
    一维树状数组单点修改-区间查询输入32123120213输出6数据范围对于所有数据,\(1≤n,q≤10^6,∣a[i]∣≤10^6,1≤l≤r≤n,∣x∣≤10^6\)。点击查看代码#include<bits/stdc++.h>#defineIOSios::sync_with_stdio(false);cin.tie(nullptr),cout.tie(nu......
  • 归并排序算法详解
    算法介绍引用百度百科的介绍。归并排序(MergeSort)是建立在归并操作上的一种有效,稳定的排序算法,该算法是采用分治法(DivideandConquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表......
  • 实验1c语言输入输出和简单程序编写
    实验任务11.竖直小人源代码1//打印一个字符小人23#include<stdio.h>4intmain()5{6printf("O\n");7printf("<H>\n");8printf("II\n");9printf("O\n");10printf("<......
  • Pytorch nn.Linear的基本用法与原理详解
    Pytorchnn.Linear的基本用法与原理详解原文:Pytorchnn.Linear的基本用法与原理详解_iioSnail的博客-CSDN博客nn.Linear的基本定义nn.Linear定义一个神经网络的线性层,方法签名如下:torch.nn.Linear(in_features,#输入的神经元个数out_features,#输出神经元个数......
  • c语言代码练习5
    #define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>#include<string.h>intmain(){inti=0;charpassword[20]={0};for(i=0;i<3;i++){printf("请输入您的密码,今天是你第%d次输入:",i+1);scanf("%s&quo......
  • 实验1 C语言输入输出和简单程序编写
    1.task.1 1#include<stdio.h>2intmain()3{4printf("O\n");5printf("<H>\n");6printf("II\n");78return0;9} task.1_11#include<stdio.h>2intmain()3{......
  • c语言代码练习4(改进)
    #define_CRT_SECURE_NO_WARNINGS1#include<stdio.h>#include<string.h>#include<windows.h>#include<stdlib.h>intmain(){/*呈现效果*################*a##############!*ay############!!*......*ayuex......