C语言----数组

本文详细介绍了C语言中一维数组、二维数组以及字符数组的基本定义、引用、初始化方法,以及字符串的处理,包括逐个字符输入输出、字符串连接、复制、比较和长度计算等函数的使用。
摘要由CSDN通过智能技术生成

数组是一组有序数据的集合。其中每一个元素都属于同一个数据类型

1.一维数组

(1)定义一维数组

定义一维数组的形式为:

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

①数组名的命名规则和变量名相同,遵循标识符命名规则。
②在定义数组时,需要指定数组中元素的个数,方括号中的常量表达式用来表示元素的个数,即数组长度。例如,指定 a [10],表示 a 数组有10个元素。注意,下标是从0开始的,这10个元素是 a [0] a [1], a [2], a [3], a [4], a [5], a [6], a [7], a [8], a [9]。请特别注意,按上面的定义,不存在数组元素 a [10]。

③常量表达式中可以包括常量和符号常量,如" int a[3+5];"是合法的。不能包含变量,如" int a[n];"是不合法的。

(2)引用一维数组

引用数组的表示形式为:
数组名[下标]

下标可以是整型常量整形表达式

(3)一维数组初始化

为了使程序简洁,常在定义数组的同时给各数组元素赋值,这称为数组的初始化

在定义数组时对全部数组元素赋予初值。如:

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

可以只给数组中的一部分元素赋值。例如:

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

如果想使一个数组中全部元素值为0.可以写成

int a[10]={0,0,0,0,0,0,0,0,0,0};

也可以为:

int a[10]={0};

在对全部数组元素赋初值时,由于数据的个数已经确定,因此可以不指定数组长度。例如:

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

如果在定义数值型数组时,指定了数组的长度并对之初始化,凡未被"初始列表"指定初始化的数组元素,系统会自动把它们初始化为0(如果是字符型数组,则初竹为'\0',如果是指针型数组,则初始化为NULL,即空指针)。

2.二维数组

二维数组常称为矩阵

(1)定义二维数组

二维数组定义一般形式为

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

前一个表达式代表,后一个表达式代表

(2)引用二维数组

二维数组元素的表示形式为

数组名[下标][下标]

例如

int a[2][3]代表a数组中序号为2的行中的序号为3的列的元素。下标应为整型表达式。可以为:

a[2-1][2*2-1],不可以为a[2,3],a[2-1,2*2-1]的形式。

(3)二维数组的初始化

分行给二维数组赋初值。例如:
int a[3][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12}};

可以将所有数据写在一个花括号内,按数组元素在内存中的排列顺序对各元素赋初值。例如:

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

可以对部分元素赋初值。例如:
int a[3][4]={{1},{5},{9}};

如果对全部元素都赋初值(即提供全部初始数据),则定义数组时对第1维的长度可以不指定,但第2维的长度不能省。例如:

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

3.字符数组

(1)定义字符数组

用来存放字符数据的数组就是字符数组

由于字符数据是以整数形式(ASCII代码)存放的,可以用整数来存放字符数据

(2)字符数据的初始化

对字符数组初始化,最容易理解的方式是用"初始化列表",把各个字符依次赋给数组中各元素。例如:

char c[10]={'I',' ','a','m',' ','h','a','p','p','y'};

如果在定义字符数组时不进行初始化,则数组中各元素的值是不可预料的。如果花括号中提供的初值个数(即字符个数)大于数组长度,则出现语法错误。如果初值个数小干数组长度,则只将这些字符赋给数组中前面那些元素,其余的元素自动定为空字符(即'\0')。

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

在C语言中,是将字符串作为字符数组来处理的。同时C语言规定了一个字符串结束标志,以字符‘\0’作为结束标志。

C 系统在用字符数组存储字符串常常量时会自动加一个'\0'作为结束符。

字符数组还有一个用字符串的初始化方式。如:

char c[10]={"I am happy"};

也可以为:

char c[10]="I am happy";

此时数组c的长度为11,不为10。因为字符串常量的最后由系统加上一个'\0'。

(4)字符数组的输入输出

逐个字符输入输出。用格式符“%c”输入或输出一个字符。

将整个字符串一次输入或输出。用“%s”格式符。

用“%s”格式输出字符串时,printf函数中的输出项为字符数组名,而不是数组元素名。如:

printf("%s",c[0]);                    //此方式错误

printf("%s",c);

如果数组长度大于字符串的实际长度,也只输出到'\0'结束。

输出时不输出'\0'。

如果一个字符数组包含多个'\0',则只输出到第一个'\0'为止。

注意:scanf函数中的输入项如果是字符数组名,则不再加&符

(5)使用字符串处理函数

①puts函数——输出字符串的函数

一般形式为

puts(字符数组)

用puts函数输出时可以包含转义字符

②gets函数——输入字符串的函数(遇回车键结束)

一般形式为:

gets(字符数组)

③strcat函数——字符串连接函数

一般形式为:
strcat(字符数组1,字符数组2){把字符数组2接到字符数组1后面}

④strcpy和strncpy函数——字符产复制函数

一般形式为:

strcpy(字符数组1,字符数组2){将字符串2复制到字符数组1后}

注意:

(a)“字符数组1”必须写成数组名形式,“字符串2”可以为字符数组名,也可以为字符串常量。

(b)如果在复制前未对str1数组初始化或赋值,则str1各字节中的内容是无法预知的,复制时将str2中的字符串和其后的'\0'一起复制到字符数组1中,取代字符数组1前面6个字符,最后4个字符并不一定是'\0',而是 strl 中原有的最后4个字节的内容。

(c)不能用赋值语句将一个字符串常量或字符数组直接给一个字符数组。
(d)可以用 strncpy 函数将字符串2中前面 n 个字符复制到字符数组1中去。例如:

strncpy(str1,str2,2);

作用是将str2中最前面2个字符复制到str1中,取代str1中原有的最前面2个字符。但复制的字符个数n不应多于strl中原有的字符(不包括'\0')。

⑤strcmp函数——字符串比较函数

一般形式为

strcpy(字符串1,字符串2)

作用是比较字符串1和字符串2长度。

(a)如全部字符相同,则认为两个字符串相等
(b)若出现不相同的字符,则以第1对不相同的字符的比较结果为准

注意:小写字母比大写字母大

如果结果为正整数,则字符串1>字符串2,反之字符串1<字符串2,如果为0,则相等

⑥strlen函数——测字符串长度的函数

一般形式为
strlen(字符数组)

⑦strlwr函数——转换为小写的函数

一般形式为

strlwr(字符串)

⑧strupr函数——转换为大写的函数

一般形式为

strupr(字符串)

注意:在使用字符串处理函数时,应当在文件的开头用#include<string.h>

(6)各类输入输出的不同

对于scanf输入字符串,遇到空格和回车键结束,而gets输入遇到回车键结束。


 


 


 


 

  • 42
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值