
问题: ■如何处理一个班学生的学习成绩? ■一行文字怎样存储? ■一个矩阵怎样存储? 这些数据的特点:1、具有相同的数据类型 2、使用过程中需要保留原始数据 C语言为这些数据提供了一种构造数据类型:数组。 组具有相同数据类型的数据的 有序集合
◼ 如何处理 一个班学生的学习成绩? ◼ 一行文字怎样存储? ◼ 一个矩阵怎样存储 ?. 问题: 一组具有相同数据类型的数据的 有序集合 这些数据的特点:1、具有相同的数据类型 2、使用过程中需要保留原始数据 C语言为这些数据提供了一种构造数据类型:数组

第六章数组 重要思想方法 连续存放、类型相同、 变量可控 内存 m[0] m/7] ml1川 m2] 各元素变量 用下标控制各 名相同 元素的访问 m/99] ?特征应用:字符处理
第六章 数组 重要思想方法: 连续存放、类型相同、变量可控 m[0] m[1] m[2] m[99] m[2] 各元素变量 名相同 用下标控制各 元素的访问 内存 67345 ?特征应用:字符处理

数组的概念 例如:存储学生成绩用整型数组 mark[100], 存储一行文字用字符数组str[200], 存储一个4*6的矩阵用二维整型数组a[4][6]。 其中:mark、str、a是数组名。 方括号内是数组的长度。 下标的个数称为数组的维数,mark、str是一维数组、 a是二维数组。 数组的成员称为数组元素。 数组元素的类型称为该数组的基类型。数组mark的基 类型是int,数组str的基类型是char
其中:mark、str、a 是数组名。 方括号内是数组的长度。 下标的个数称为数组的维数,mark、str是一维数组、 a是二维数组。 数组的成员称为数组元素。 数组元素的类型称为该数组的基类型。数组mark的基 类型是int,数组str的基类型是char。 数组的概念 例如:存储学生成绩用整型数组 mark[100], 存储一行文字用字符数组 str[200], 存储一个4*6的矩阵用二维整型数组 a[4][6]

第大章 数组 ·构造数据类型之一 []数组运算符 ·数组:有序数据的集合,用数组名标识 单目运算符 ·元素:属同一数据类型,用数组名和下标确定优先级(1) §6.1 一维数组 左结合 不能用() ★一维数组的定义 必定义方式: 数据类型 数组名[常量表达式]; 例 int a[6]; 合法标识符 表示元素个数 a a0] 下标从0开始 a[1] a[2] 编译时分配连续内存 a[3] 数组名表示内存首地址, 内存字节数=数组维数* 是地址常量 a[4] sizeof元素数据类型) a[]
第六章 数组 •构造数据类型之一 •数组:有序数据的集合,用数组名标识 •元素:属同一数据类型,用数组名和下标确定 §6.1 一维数组 一维数组的定义 ❖定义方式: 数据类型 数组名[常量表达式]; 合法标识符 表示元素个数 下标从0开始 [ ] :数组运算符 单目运算符 优先级(1) 左结合 不能用( ) 例 int a[6]; 0 a[0] 1 4 5 a[1] a[2] a[3] a[4] a[5] 2 3 a 编译时分配连续内存 内存字节数=数组维数* sizeof(元素数据类型) 数组名表示内存首地址, 是地址常量

例 int data[5]; data[5]=10; /C语言对数组不作越界检查,使用时要注意 冬数组必须先定义,后使用 》只能逐个引用数组元素,不能一次引用整个数组 公数组元素表示形式:数组名[下标] 其中:下标可以是常量或整型表达式 例 int a[10]; printf("d",a); (x) 必须 forj=0j<10:j++) printfd\t”,a[j]);
一维数组的引用 ❖数组必须先定义,后使用 ❖只能逐个引用数组元素,不能一次引用整个数组 ❖数组元素表示形式: 数组名[下标] 其中:下标可以是常量或整型表达式 例 int i=15; int data[i]; (不能用变量定义数组维数) 例 int a[10]; printf(“%d”,a); () 必须 for(j=0;j<10;j++) printf(“%d\t”,a[j]); () 例 int data[5]; data[5]=10; //C语言对数组不作越界检查,使用时要 注意

★一维数组的初始化 冬初始化方式 inta[5]={1,2,3,4,5}; 等价于:a[0]=1;a[1]=2,a[2]=3,a[3]=4;a[4]=5; 》说明: ●数组不初始化,其元素值为随机数 ●对static数组元素不赋初值,系统会自动赋以0值 ●只给部分数组元素赋初值 。出今产R数细示表础m估计可T不些启数细上准 inta0={1,2,3,4,5,6}; 编译系统根据初值个数确定数组维数
一维数组的初始化 ❖初始化方式 在定义数组时,为数组元素赋初值 (在编译阶段使之得到初值) int a[5]={1,2,3,4,5}; 等价于:a[0]=1; a[1]=2; a[2]=3; a[3]=4; a[4]=5; ❖说明: ⚫数组不初始化,其元素值为随机数 ⚫对static数组元素不赋初值,系统会自动赋以0值 ⚫当全部数组元素赋初值时,可不指定数组长度 如 static int a[5]={6,2,3}; 等价于: a[0]=6; a[1]=2;a[2]=3; a[3]=0; a[4]=0; 如 int a[3]={6,2,3,5,1}; () static int a[5]; 等价于:a[0]=0; a[1]=0; a[2]=0; a[3]=0; a[4]=0; ⚫只给部分数组元素赋初值 int a[]={1,2,3,4,5,6}; 编译系统根据初值个数确定数组维数

★程序举例 从键盘输入10个整数存入到一个一维数组中,然后再按逆序输出。 mainO int a[10],i; for(i=0;i=0;i-) printf("%d ",ali]); printf("\n");
从键盘输入10个整数存入到一个一维数组中,然后再按逆序输出。 程序举例 main() { int a[10], i; for(i=0;i=0;i-) printf("%d ",a[i]); printf("\n"); }

★程序举例 例读10个整数存入数组,找出其中最大值 #include 步骤 mainO) 1.输入for循环输入 int x[10],i,max; 2.处理 printf("Enter 10 integers:\n"); (a)先令max=x[0] for(i=0;i10;i++) (b)依次用x[i]和max scanf("%d",&xi); 若max<x[i,令ma max-x[O]; 3.输出:max for(i=1;i<10;i++) if(max<x[i])max=x[i]; printf("Maximum value is %d\n",max);
例 读10个整数存入数组,找出其中最大值 步骤: 1. 输入:for循环输入10个整数 2. 处理: (a) 先令max=x[0] (b) 依次用x[i]和max比较(循环) 若max main() { int x[10],i,max; printf("Enter 10 integers:\n"); for(i=0;i<10;i++) scanf("%d",&x[i]); max=x[0]; for(i=1;i<10;i++) if(max<x[i]) max=x[i]; printf("Maximum value is %d\n",max); } 程序举例

★程序举例 例读10个整数存入数组,找出其中最小值 #include main() 步骤: int x[10],i,min; 1.输入:for循环输入10 printf("Enter 10 integers:\n"); 2.处理 for(i=0;ix[i],令min=y for(i=1;ix[i])min=x[i]; printf("Minimum value is %d\n",min);
例 读10个整数存入数组,找出其中最小值 步骤: 1. 输入:for循环输入10个整数 2. 处理: (a) 先令min=x[0] (b) 依次用x[i]和min比较(循环) 若min>x[i],令min=x[i] 3. 输出:min #include main() { int x[10],i,min; printf("Enter 10 integers:\n"); for(i=0;ix[i]) min=x[i]; printf("Minimum value is %d\n",min); } 程序举例

★程序举例 例读10个整数存入数组,找出其中最大值和最小值 #include 步骤 mainO 1.输入:for循环输入1 int x[10],i,max,min; 2.处理 printf("Enter 10 integers:\n"); (a)先令max=min=x[0 for(i=0;ix[i],令min for(i=1;ix[i])min=x[i]; printf("Maximum value is %d n",max); printf("Minimum value is %d\n",min);
例 读10个整数存入数组,找出其中最大值和最小值 步骤: 1. 输入:for循环输入10个整数 2. 处理: (a) 先令max=min=x[0] (b) 依次用x[i]和max,min比较(循环) 若maxx[i],令min=x[i] 3. 输出:max和min #include main() { int x[10],i,max,min; printf("Enter 10 integers:\n"); for(i=0;ix[i]) min=x[i]; } printf("Maximum value is %d\n",max); printf("Minimum value is %d\n",min); } 程序举例