C语言-数组的定义和引用
数组的定义和引用
- 1. 一维数组、二维数组的定义、初始化和引用方法
- 数组数据的特点:
- 数组:
- 一般形式:类型说明符 数组名[常量表达式];
- 说明:
- 一维数组的引用
- 1. 引用方式:
- 二维数组
- 二维数组引用
- 表现形式:
- 引用
- 二维数组的定义
- 四种方法对二维数组初始化
- 2.一维数组的应用(如排序),二维数组的应用(如矩阵运算)
- 3.数组作函数参数
- 4.字符数组的定义、初始化和输入输出方法
- 字符数组的定义
- 字符数组的初始化
- 元素的引用
- 结束标志
- 输入输出
- 应用举例
- 5.字符串处理函数的使用
- puts函数
- 实例:
- gets函数
- 实例:
- strcat函数
- strcpy函数
- strcmp函数
- strlen函数
- strlwr函数
- strupr函数
1. 一维数组、二维数组的定义、初始化和引用方法
数组数据的特点:
- 具有相同的数据类型
- 使用过程中需要保留原始数据
数组:
是一种具有相同数据类型的数据的有序集合
一般形式:类型说明符 数组名[常量表达式];
例如:int a[10];
元素为a[0]----a[9]、2、常量表达式中不允许包含变量,可以包含常量或符号常量。
说明:
- 数组名定义规则和变量名相同,遵循标识符定名规则
- 在定义数组时,需要指定数组中的元素个数,方括号中的常量表达式用来表示元素的个数,即数组长度。从下标0开始
- 常量表达式中可以包括常量和符号常量,但不能包括变量。也就是说C语言不允许对数组的大小作动态定义,即数组的大小不依赖与程序运行过程中变量的值。
- 数组元素下标可以是任何整型常量、整型变量或任何整型表达式。
- 使用数值型数组时,不可以一次引用整个数组,只能逐个引用元素
- 需要整体赋值时只可以在定义的同时整体赋值。
如
int a[10]={0,1,2,3,4,5,6,7,8,9};
正确。i nt a[10];a[10]={0,1,2,3,4,5,6,7,8,9};
错误。
- 可以只给一部分元素赋值。
例如:
int a[10]={5,8,7,6};
后面没有赋值的元素值默认为0
- 对全部数组元素赋值时可以不指定数组长度,
例如:
int a[10]={0,1,2,3,4,5,6,7,8,9};可以写成 int a[]={0,1,2,3,4,5,6,7,8,9};
但是,既不赋初值,也不指定长度是错误的。例如:int a[];错误。
一维数组的引用
1. 引用方式:
数组名[下标]
下标可以是整型常量或整型表达式。
例如:a[0]=a[5]+a[7]-a[2*3]
例子:
#include <stdio.h>int main()
{int i, a[10];for (i = 0; i <= 9; i++)a[i] = i;for (i = 9; i >= 0; i--)printf("%d", a[i]);printf("\n");
}
2. 对数组元素初始化的实现方法
在定义数组时对数组元素赋以初值。
例如:int a[10]={0,1,2,3,4,5,6,7,8,9};
二维数组
一般形式:类型说明符 数组名[常量表达式1][常量表达式2]
;例如:
int a[3][4];
可以看成是包含3个一维数组,每个一维数组里包含4个元素。一共3*4=12个元素。
二维数组引用
表现形式:
数组名 [下标] [下标]
例如 a[2][3]
引用
数据类型
数组名 [常量表达式1][常量表达式2]={初始化数据}
二维数组的定义
二维数组中的元素在内存中的排序顺序是:按行存放,即先顺序存放第一行的元素,在存放第二行的元素
四种方法对二维数组初始化
- 分行给二维数组赋初值:
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}}
- 如果对全部元素都赋初值,则定义数组时对第一维的长度可以不指定,但第二维的长度不能省。
2.一维数组的应用(如排序),二维数组的应用(如矩阵运算)
用冒泡法对两个数比较,将最小的掉在前头
#include <stdio.h>int main()
{int a[10];int i, j, t;printf("input 10 numbera:\n ");for (i = 0; i < 10; i++)scanf("%d", &a[i]);printf("\n ");for (j = 0; j < 9; j++)for (i = 0; i < 9 - j; i++){if (a[i] > a[i + 1]){t = a[i];a[i] = a[i + 1];a[i + 1] = t;}}printf("the sorted numbers:");printf("\n ");for (i = 0; i < 10; i++){printf("%d ", a[i]);}
}
有一个3*4的矩阵,要求编程序求出其中值最大的那个元素的值,以及其所在的行号和列号
#include <stdio.h>int main()
{int i, j, row = 0, colum = 0, max;int a[3][4] = {{1, 2, 3, 4}, {9, 8, 7, 6}, {-10, -10, -5, 2}};max = a[0][0];for (i = 0; i <= 2; i++)for (j = 0; j <= 3; j++)if (a[i][j] > max){max = a[i][j];row = i;colum = j;}printf("max=%d,row=%d,colum=%d\n", max, row, colum);
}
3.数组作函数参数
数组作函数参数
4.字符数组的定义、初始化和输入输出方法
字符数组的定义
用来存放字符数据的数组称为字符数组。字符数组中的一个元素存放一个字符。定义字符数组的方法与定义数值型数组的方法类似。
其定义的一般形式是:char 数组名[数据长度]
例如:
char c[10];
c[0]=‘I’; c[1]=’ ‘; c[2]=‘l’; c[3]=‘o’; c[4]=‘v’; c[5]=‘e’; c[6]=’ '; c[7]=‘y’; c[8]=‘o’; c[9]=‘u’;
以上定义了c为字符数组,包含10个元素。
由于字符型数据是以整数形式(ASCII代码)存放的,因此也可以用整型数组来存放字符数据,例如:
int c[10];
但这时每个数组元素占2个字节的内存单元,浪费存储空间。 [1]
字符数组也可以是二维或多维数组,例如:
char c[5][10];
即为二维字符数组。
字符数组的初始化
字符数组的初始化与数值型数组初始化没有本质区别。但它除了可以逐个给数组元素赋予字符外,也可以直接用字符串对其初始化。
- (1)用字符常量逐个初始化数组。例如:
char a[8]={‘i’,‘l’,‘o’,‘v’,‘e’,‘y’,‘o’,‘u’};
把8个字符依次分别赋给c[0]~c[7]这8个元素。
如果在定义字符数组时不进行初始化,则数组中各元素的值是不可预料的。如果花括号中提供的初值个数(即字符个数)大于数组长度,则出现语法错误。如果初值个数小于数组长度,则只将这些字符赋给数组中前面那些元素,其余的元素自动定为空字符(即’\0’)。如果提供的初值个数与预定的数组长度相同,在定义时可以省略数组长度,系统会自动根据初值个数确定数组长度
。例如:
char c[ ]={‘c’,‘ ’,‘p’,‘r’,‘o','g','r','a','m'};
这时c数组的长度自动定为9。
也可以定义和初始化一个二维字符数组,例如:
char diamond[5][5]={{’ ‘,’ ‘,’#’},{’ ‘,’#’,’ ‘,’#’},
{’#’,’ ‘,’ ‘,’ ‘,’#’},{’ ‘,’#’,’ ‘,’#’},{’ ‘,’ ‘,’#’}};用它代表一个菱形的平面图形。
2. (2)字符串常量初始化数组。例如:
char c[ ]={‘c’,‘ ’,‘p’,‘r’,‘o','g','r','a','m'};
可写为:
char c[ ]={"C program"};
或去掉{}写为:
char c[ ]="C program";
注意:此时数组c的长度不是9,而是10。因为字符串常量的最后由系统加上一个’\0’。上面的初始化与下面的初始化等价。
char c[ ]={‘c’,‘ ’,‘p’,‘r’,‘o','g','r','a','m','\0'}; [1]
元素的引用
可以通过引用字符数组中的一个元素,得到一个字符。
数组的引用形式为:
数组名[下标]
【例5-8】输入“I like playing basketball”并显示出来。
#include<stdio.h>
int main(void)
{char a[26]="I like playing basketball";
int i;
for(i=0;i<26;i++)
printf("%c",a[i]);
}
运行结果为:I like playing basketball [2]
结束标志
字符串和字符串结束标志
在C语言中,是将字符串作为字符数组来处理的。为了测定字符串的实际长度,C语言规定了一个“字符串结束标志”,以字符’\0’作为结束标志 [1] 。
输入输出
- 字符数组的输入:
(1)用getchar()或scanf()的’%c’格式符对数组进行字符赋值。例如,对于数组a[10]:用getchar()赋值:for(i=0;i<10;i++)a[i]=getchar();用scanf()赋值:for(i=0;i<10;i++)scanf("%c",&a[i]);
(2)用scanf()的’%s’格式对数组赋值。还是对于数组a[10]:scanf("%s",a);或scanf("%s“,&a[0]);输入”C
program“并回车时,a数组会自动包含一个以”\0“结尾的字符串”C program“。
- 字符数组的输出
(1)用putchar()或printf()的‘%c’格式符对数组进行字符赋值。例如,对于数组a[10]:用putchar()赋值:for(i=0;i<10;i++)a[i]=putchar();用printf()赋值:for(i=0;i<10;i++)printf("%c",a[i]);输出结果为:c program
(2)用printf()的’%s’格式对数组赋值。还是对于数组a[10];printf("%s",a);输出结果为:c program
应用举例
#include <stdio.h>
int main()
{char string[81];int i, num = 0, word = 0;char c;gets(string);for (i = 0; (c = string[i]) != '\0'; i++)if (c == ' ')word = 0;else if (word == 0){word = 1;num++;}printf("There are %d words in this line.\n", num);
}
5.字符串处理函数的使用
puts函数
C 库函数 int puts(const char *str) 把一个字符串写入到标准输出stdout,直到空字符,但不包括空字符。换行符会被追加到输出中。
int puts(const char *str)
实例:
#include <stdio.h>
#include <string.h>int main()
{char str1[15];char str2[15];strcpy(str1, "RUNOOB1");strcpy(str2, "RUNOOB2");puts(str1);puts(str2);return(0);
}
gets函数
C 库函数 char *gets(char *str) 从标准输入 stdin 读取一行,并把它存储在 str所指向的字符串中。当读取到换行符时,或者到达文件末尾时,它会停止,具体视情况而定。
char *gets(char *str)
str – 这是指向一个字符数组的指针,该数组存储了 C 字符串
实例:
#include <stdio.h>int main()
{char str[50];printf("请输入一个字符串:");gets(str);printf("您输入的字符串是:%s", str);return(0);
}
strcat函数
C 库函数 char *strcat(char *dest, const char *src) 把 src 所指向的字符串追加到 dest所指向的字符串的结尾。
char *strcat(char *dest, const char *src)
dest – 指向目标数组,该数组包含了一个 C 字符串,且足够容纳追加后的字符串。
src – 指向要追加的字符串,该字符串不会覆盖目标字符串。
#include <stdio.h>
#include <string.h>int main ()
{char src[50], dest[50];strcpy(src, "This is source");strcpy(dest, "This is destination");strcat(dest, src);printf("最终的目标字符串: |%s|", dest);return(0);
}
strcpy函数
char *strcpy(char *dest, const char *src)
dest – 指向用于存储复制内容的目标数组。
src – 要复制的字符串。
char *strcpy(char *dest, const char *src) 把 src 所指向的字符串复制到 dest。
需要注意的是如果目标数组 dest 不够大,而源字符串的长度又太长,可能会造成缓冲溢出的情况
#include <stdio.h>
#include <string.h>int main()
{char src[40];char dest[100];memset(dest, '\0', sizeof(dest));strcpy(src, "This is runoob.com");strcpy(dest, src);printf("最终的目标字符串: %s\n", dest);return(0);
}
strcmp函数
strcmp compare(字符串比较)的缩写,用于比较两个字符串并根据比较结果返回整数。基本形式为strcmp(str1,str2),若str1=str2,则返回零;若str1<str2,则返回负数;若str1>str2,则返回正数。
#include <stdio.h>
#include <string.h>int main ()
{char str1[15];char str2[15];int ret;strcpy(str1, "abcdef");strcpy(str2, "ABCDEF");ret = strcmp(str1, str2);if(ret < 0){printf("str1 小于 str2");}else if(ret > 0) {printf("str1 大于 str2");}else {printf("str1 等于 str2");}return(0);
}
特别注意:strcmp(const char *s1,const char * s2) 这里面只能比较字符串,即可用于比较两个字符串常量,或比较数组和字符串常量,不能比较数字等其他形式的参数。
ANSI 标准规定,返回值为正数,负数,0 。而确切数值是依赖不同的C实现的。
当两个字符串不相等时,C 标准没有规定返回值会是 1 或 -1,只规定了正数和负数。
有些会把两个字符的 ASCII 码之差作为比较结果由函数值返回。但无论如何不能以此条依据作为程序中的流程逻辑
strlen函数
计算字符串 str 的长度,直到空结束字符,但不包括空结束字符
#include <stdio.h>
#include <string.h>int main()
{char str[50];int len;strcpy(str, "This is runoob.com");len = strlen(str);printf("|%s| 的长度是 |%d|\n", str, len);return (0);
}
strlwr函数
strlwr(string)函数返回给定字符串的小写形式。
#include<stdio.h> int main() {char str[20];printf("Enter string: ");gets(str);//reads string from console printf("String is: %s", str);printf("
Lower String is: %s", strlwr(str));}
strupr函数
strupr(string)函数返回给定字符串的大写形式
#include<stdio.h> int main() {char str[20];printf("Enter string: ");gets(str);//reads string from console printf("String is: %s",str); printf("\nUpper String is: %s \n",strupr(str));
}
C语言-数组的定义和引用相关推荐
- c语言向自定数组_C语言一维数组的定义和引用
C语言一维数组的定义和引用 C语言支持一维数组和多维数组.如果一个数组的所有元素都不是数组,那么该数组称为一维数组. 一维数组的定义方式 在C语言中使用数组必须先进行定义.一维数组的定义方式为: 类型 ...
- Nwafu-Oj-1444 Problem l C语言实习题七——2.结构体数组的定义与引用
问题 : C语言实习题七--2.结构体数组的定义与引用 时间限制: 1 Sec 内存限制: 128 MB 提交: 4459 解决: 2011 [提交][状态][讨论版] 题目描述 定义一个职工结构 ...
- c语言中的一维数组的定义,C语言一维数组的定义和引用
<C语言一维数组的定义和引用>由会员分享,可在线阅读,更多相关<C语言一维数组的定义和引用(5页珍藏版)>请在人人文库网上搜索. 1.C语言一维数组的定义和引用在程序设计中,为 ...
- c语言中结构体数组的引用,【C语言入门教程】7.2 结构体数组的定义和引用
7.2 结构体数组的定义和引用 当需要使用大量的结构体变量时,可使用结构体定义数组,该数组包含与结构体相同的数据结构所组成的连续存储空间.如下例所示: struct student stu_a[50] ...
- 实验十——一维数组的定义及引用
1.本次课学习到的知识点: (1):一维数组的定义与引用:定义一个数组,需要明确数组变量名,数组元素的类型和数组的大小. (2):一堆数组定义的一般定义. 本次课的学习重点是比以往的更复杂的数据类型, ...
- C语言-二维数组的定义、引用
定义 由行和列组成的二维表格形式元素,二维数组其实也就是矩阵 基本格式:数据类型 数组名[行长度][列长度]; 行长度为二维数组行的个数,必须为常量表达式,不能为变量 列长度为二维数组每一行列的个数, ...
- c#数组赋初值_c语言数组的定义及赋值
一维数组的定义方式如下:类型说明符 数组名[常量表达式]; 例如:int a[5]; 它表示定义了一个整型数组,数组名为 a,定义的数组称为数组 a. 此时数组 a 中有 5 个元素,每个元素都是 i ...
- c语言提高 17,C语言提高-第17讲: 一维数组的定义和引用(数组大折腾)
知识点总结: (1)一维数组的初始化 a).在定义数组时分别对数组元素赋予初值,如int a[5]={0,1,2,3,4}; b).可以只给一部分元素赋值,如int a[5]={0,1}; 剩余元素均 ...
- c语言一维数组定义可用字母吗,C语言一维数组的定义和引用
(一)维数组的界说和引证 在程序设计中,为了处置便利,把具有一样类型的若干变量按有序的办法组织起来.这些按序摆放的同类数据元素的调集称为数组.在C言语中,数组归于布局数据类型.一个数组能够分化为多个数 ...
最新文章
- 科研文献|粪便污染可以解释人为影响环境中抗生素耐药基因丰度
- hicoder - 1068 【RMQ or 线段树】
- 李沐在斯坦福开新课了!面向机器学习实战,课程全部免费,9月1日可报名
- MYSQL limit,offset 区别
- IPC$连接常见问答
- std::remove
- [bbk3100]第7集 - Chapter 04 - 介绍RAC中CVU工具的使用
- 【牛客 - 185B】路径数量(离散数学,长度为k的路径数量,图)
- 乐高创意机器人moc_乐高MOC作品欣赏:变形金刚及其他
- 删除none 的images报错 image has dependent child images 解决办法
- 2021年4月自考04741计算机网络原理试卷
- 判定覆盖与条件覆盖的区别
- Mysql SQLserver Oracle 数据库中获取系统时间,年,月,日单个获取
- 百度劫持有哪些特征,百度快照劫持处理方法及流程?
- Unity-协成-开启关闭
- opencv+QT+vs 中显示图片总结
- Poi解析对比excel表格
- 360极速浏览器显示密码
- 云平台的几个概念和典型平台关系对比
- nltk学习之统计词频和分词nltk.word_tokenize nltk.FreqDist