【C语言】数组的声明和使用(一维数组、多维数组、字符数组)

这篇具有很好参考价值的文章主要介绍了【C语言】数组的声明和使用(一维数组、多维数组、字符数组)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、什么是数组?

C语言支持数组数据结构,是用来存储固定大小的相同类型元素的顺序集合,往往被认为是一系列相同类型的变量。

特点:

  1. 有序数据的集合。
  2. 数组内所有元素类型相同。
  3. 所有的数组都是由连续的内存位置组成,最低的地址对应第一个元素,最高的地址对应最后一个元素。
  4. 数组中的特定元素可以通过索引访问,第一个索引值为 0。

c语言声明数组,C语言,c语言,数据结构,算法

二、一维数组

(一)一维数组声明

在 C 中要声明一个数组,需要指定元素的类型和元素的数量,一维数组定义:

类型说明符	数组名[常量表达式];

注意:

  1. 数组名必须是合法的标识符
  2. [ ]中的内容可以是常量和符号常量,不可以是变量

例如:

int a[10];

a为整型数组名,含有10个元素:a0, a1, a2 … a9 。
c语言声明数组,C语言,c语言,数据结构,算法

(二)一维数组初始化

在 C 语言中,可以逐个初始化数组,也可以使用一个初始化语句,对数组元素的初始化可以用以下方式实现:
(1)在定义数组时对数组元素赋初值。
例如:

int a[10]={0,1,2,3,4,5,6,7,8,9};

此实数组元素的值为:

a[0]=0,a[1]=1,a[2]=2,a[3]=3,a[4]=4,a[5]=5,a[6]=6,a[7]=7,a[8]=8,a[9]=9

注意:大括号 { } 之间的值的数目不能大于我们在数组声明时在方括号 [ ] 中指定的元素数目。

(2)只给一部分元素赋初值。
例如:

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

数组a定义了10个元素,但是{}内只提供了4个初值,表示只给前4个元素赋值,后6个元素值为0。

(3)在对全部数组元素赋初值时,可以不指定数组长度,此时数组的长度就是初值的个数。
例如:

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

此时定义了数组长度为5的数组a,并全部元素赋初值。

(三)一维数组的引用

数组元素可以通过数组名称加索引进行访问,元素的索引是放在方括号内,跟在数组名称的后边。只能逐个引用数组元素,而不能一次引用整个数组,例如:

int b = a[index];

index为数组下标,可以是整型常量或者整型表达式,数组下标范围:0~(n-1),n为数组长度,使用数组时注意防止下标越界。

三、多维数组(以二维数组为例)

C 语言支持多维数组。多维数组声明的一般形式如下:

type arrayName[size1][size2]...[sizeN];

下面以二维数组为例进行介绍。

(一)二维数组声明

多维数组最简单的形式是二维数组。一个二维数组,在本质上,是一个一维数组的列表。声明一个 x 行 y 列的二维整型数组,形式如下:

type arrayName [x][y];

其中,type 可以是任意有效的 C 数据类型,arrayName 是一个有效的 C 标识符。一个二维数组可以被认为是一个带有 x 行和 y 列的表格。下面是一个二维数组,包含 3 行和 4 列:

int a[3][4];

c语言声明数组,C语言,c语言,数据结构,算法
因此,数组中的每个元素是使用形式为 a[ i , j ] 的元素名称来标识的,其中 a 是数组名称,i 和 j 是唯一标识 a 中每个元素的下标。

(二)二维数初始化

二维数组初始化可以使用如下方法:

(1)分行为二维数组赋初值。例如:

int a[3][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};

(2)可以将所有的数组给到一个{ }内,按数组排列的顺序对各元素赋值。例如:

int a[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12};

(3)可以对部分元素赋初值。例如:

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

此时对二维数组各行的第一列元素赋初值,其余元素为0,赋值后的数组元素为:
1 0 0 0
5 0 0 0
9 0 0 0

也可以对各行的某一元素赋初值,例如:

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

赋值后的数组元素为:
1 0 0 0
0 5 0 0
9 0 2 0

(4)如果对全部元素赋初值,则定义数组时可以不指定第一维的长度,但是不能省略第二维的长度。例如:

int a[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12};

等价于:

int a[][4] = {1,2,3,4,5,6,7,8,9,10,11,12};

系统会根据数据的总数分配存储空间,一共12个数据,每行4列,可以确定3行。

(5)可以只对部分元素赋初值而省略第一维的长度,但是要分行赋初值。例如:

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

此时,数组元素为:
1 0 2 0
5 0 0 0
0 0 0 0

(三)二维数组的引用

二维数组中的元素是通过使用下标(即数组的行索引和列索引)来访问的。例如:

int b = a[2][3];

(1)二维数组元素的表现形式为:数组名 [下标][下标]
(2)二维数组的元素可以出现在表达式中,也可以被赋值。
(3)使用二维数组元素时,注意下标值是否在定义的数组大小范围内,防止下标越界。

四、字符数组

(一)字符数组定义

字符数组定义方式:

char  字符数组名[常量表达式]

例如:

char c[10];

以上表示定义了一个字符数组c,包含10个元素。

(二)字符数组初始化

1、单个字符方式赋初值
例如:

char c[] = {'I',' ','a','m',' ','a',' ','s','t','u','d','e','n','t',};

2、在初值表中给一个字符串常量
例如:

char c[] = {"I am a student"};

(三)字符数组的引用

符数组的引用和一维数组引用方式一致。
例如:

#include <stdio.h>

int main(){
    char c[] = {'I',' ','a','m',' ','a',' ','s','t','u','d','e','n','t',};
    for (int i = 0; i < 14; i++){
        printf("%c",c[i]);
    }
    
    return 0;
}

(四)字符串和字符串结束标志

在C语言中,将字符串作为字符数组进行处理。字符串必须要有一个字符串结束标志’\0’。字符串的长度为字符串所包含的字符个数,不包含’\0’。因此,如果将字符串"I am a student"放在字符数组中,则数组所需长度为15。

c语言声明数组,C语言,c语言,数据结构,算法

(五)字符串处理函数

1、puts(字符数组)
作用:将字符串(以\0结束的字符序列)输出到终端
例如:

#include <stdio.h>
int main(){
    char c[] = {"I am a student"};
    puts(c);
    return 0;
}

运行结果:
c语言声明数组,C语言,c语言,数据结构,算法
2、gets(字符数组)
作用:从终端输入一个字符串到字符数组,并得到一个函数值,该函数值是字符数组的首地址。
例如:

#include <stdio.h>
int main(){
    char c[] = {};
    printf("请输入一个字符串:");
    gets(c);
    puts(c);
    
    return 0;
}

运行结果:
c语言声明数组,C语言,c语言,数据结构,算法
注意:
(1)使用gets和puts只能输入或输出一个字符串
(2)gets(str) str要以回车结束
3、strcat(字符数组1,字符数组2)
作用:连接两个字符数组中的字符串,将字符串2连接到字符串1后面,结果放在字符数组1中,函数调用后得到一个函数值,即字符数组1的地址。
例如:

#include <stdio.h>
#include <string.h>

int main(){
    char str1[20] = {"I am a "};
    char str2[] = {"student"};
    printf("%s",strcat(str1,str2));
    
    return 0;
}

运行结果:
c语言声明数组,C语言,c语言,数据结构,算法
注意:
(1)字符数组1必须足够大,以便容纳连接以后的新字符串
(2)连接前两个字符串后面都有一个'\0',连接时将字符串1后面的'\0'取消,只在新字符串最后保存'\0'
4、strcpyt(字符串1,字符串2)
作用:将字符串2赋值到字符串1中
例如:

#include <stdio.h>
#include <string.h>

int main(){
    char str1[20];
    char str2[] = {"I am a student"};
    strcpy(str1,str2);
    printf("str1: %s\n",str1);
    printf("str2: %s",str2);
    return 0;
}

运行结果:
c语言声明数组,C语言,c语言,数据结构,算法
5、strcmp(字符串1,字符串2)
作用:比较字符串1和字符串2,比较结果由函数值返回
(1)字符串1=字符串2,函数值为0
(2)字符串1>字符串2,函数值为正整数
(3)字符串1<字符串2,函数值为负整数
6、strlen(字符数组)
作用:测试字符串长度,函数的值为字符串的实际长度,不包括’\0’
例如:

#include <stdio.h>
#include <string.h>

int main(){
    char str1[] = {"I am a student"};
    printf("str1长度为: %d",strlen(str1));
    return 0;
}

运行结果:
c语言声明数组,C语言,c语言,数据结构,算法
7、strlwr(字符串)
作用:将字符串中的大写字母转换成小写字母
例如:

#include <stdio.h>
#include <string.h>

int main(){
    char str1[] = {"I Am A Student"};
    strlwr(str1);
    printf("str1: %s",str1);
    return 0;
}

运行结果:
c语言声明数组,C语言,c语言,数据结构,算法

8、strupr(字符串)
作用:将字符串中的小写字母转换成大写字母
例如:

#include <stdio.h>
#include <string.h>

int main(){
    char str1[] = {"I am a student"};
    strupr(str1);
    printf("str1: %s",str1);
    return 0;
}

运行结果:
c语言声明数组,C语言,c语言,数据结构,算法文章来源地址https://www.toymoban.com/news/detail-597474.html

到了这里,关于【C语言】数组的声明和使用(一维数组、多维数组、字符数组)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Visual Studio 2022环境中C语言的使用——一维数组和二维数组

    我是荔园微风,作为一名在IT界整整25年的老兵,今天总结一下,Visual Studio 2022环境中,是如何使用C语言的数组的。 先说一维数组,直接上代码: 这里特别容易搞错的就是一维数组的初始化,方法有如下几种: 1.在定义数组时直接对数组元素赋初值,例如: int iArray[6]={1,3,

    2024年02月05日
    浏览(79)
  • 5.一维数组与字符数组

    数组:指一组具有相同数据类型的数据的有序集合。 一维数组的定义格式为 类型说明符 数组名[常量表达式]; 常量表达式中可以包含常量和符号常量,但不能包含变量 可以只给一部分元素赋值,如int a[10]={0,1,2,3,4};后面的值会默认为0 在对全部数组元素赋初值时,由于数据的

    2024年02月12日
    浏览(38)
  • C 多维数组、特殊字符和字符串函数详解

    数组,也称为单维数组。这些非常棒,是您在 C 语言编程中会经常使用的东西。然而,如果您想要将数据存储为表格形式,例如带有行和列的表格,则需要熟悉多维数组。 二维数组也称为矩阵,具有行和列的结构。 第一个维度表示行数 [2],而第二个维度表示列数 [3]。 要访

    2024年02月03日
    浏览(68)
  • 数据结构学习笔记——多维数组、矩阵

    数组是由n(n≥1)个 相同数据类型 的数据元素组成的有限序列,在定义数组时,会为数组分配一个固定大小的内存空间,用来存储元素,数组在被定义后,其维度不可以被改变。 数组在确定其维度和维界后,元素的个数是固定的,所以不能进行插入和删除运算。数组中最常

    2024年02月03日
    浏览(48)
  • Go语言变量使用指南:声明、类型转换与字符串操作

    深入了解Go语言中变量的声明方式、字符和布尔类型的细节、字符串的不可变性以及基本数据类型之间的转换规则。

    2024年02月10日
    浏览(86)
  • 【数据结构】——多维数组、矩阵以及广义表的相关习题

    1、数组通常具有的两种基本操作是()。 A、查找和修改 B、查找和索引 C、索引和修改 D、建立和删除 解析: (A) 基本操作是查找和修改,其中每个元素都可以通过其索引来访问,这是从数组的第一个元素开始计算的。除了访问和修改数组元素之外,还可以执行其他一些操

    2024年02月04日
    浏览(36)
  • 数据结构与算法—一维数组、二维数组、矩阵、顺序串、链接串的C++代码实现

    1、一维数组:ArrayOneD.h 数组这种数据结构可以看作线性表的推广。数组一般采用顺序存储的方法表示。 这是一个模板类 ArrayOneD 的实现,用于表示一维数组。它包括了 构造函数、拷贝构造函数、析构函数、重载下标运算符、重载赋值运算符、求数组长度、重新设置数组长度

    2024年02月07日
    浏览(60)
  • 数据结构:求一维数组中的最大值最小值

    思路: 对于一维数组中的元素,赋max,min的初值为数组的第一个元素,然后将数组中剩余的元素依次和max值最小值比较。 代码: 分析:该算法的最好、最坏和平均情况下的元素比较次数分别为n-1,2(n-1),3(n-1)/2 该算法的时间最主要花费在元素的比较上。最好情况是a中元素呈

    2024年02月07日
    浏览(48)
  • C语言好好题(一维数组)

    两天没有更新了,贴纸们,有没有想我呀。😄😄😄 好了,就寒暄到这里吧,下面请看题: 有序序列判断 输入一个整数序列,判断是否是有序序列,有序,指序列中的整数从小到大排序或者从大到小排序(相同元素也视为有序 输入描述: 第一行输入一个整数N(3≤N≤50)。 第

    2024年02月05日
    浏览(39)
  • C语言中一维数组及二维数组的运用

    int * p  = arr; int * q = arr[1]; 其中arr是数组名,代表了整个数组的首元素地址,这个是一个常量,放在常量存储区,所以在给int*p赋值的时候可以不用带,而下面的arr[1]则代表数组里的某一个元素,所以在赋值时要加上  有个例题: 下列运行结果  解析:首先看main函数里的第二

    2024年02月13日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包