第七章 数组
C语言程序设计(第3版)何钦铭 颜 晖 第7章 数组

第7章数组【练习7-1】将例7—3 程序中的break 语句去掉,输出结果有变化吗?假设输入数据不变,输出什么?解答:当去掉break 语句后,一旦找到数据将不跳出循环,而是继续往下找值为x 的元素,因此程序输出会有变化。
当输入数据仍为2 9 8 1 9 时,输出将是index is 1 index is 4。
【练习7—2】将数组中的数逆序存放.输入一个正整数n(1<n<=10),再输入n个整数,存入数组a中,输出最大值及其对应的最小下标,下标从0开始.试编写相应程序。
解答:#include<stdio。
h〉int main(void){int i,n,temp;int a[10];printf("Input n:");scanf(”%d",&n);printf(”Input %d integer:",n);for(i=0;i<n;i++)scanf(”%d”,&a[i]);printf(”After reversed:");for(i=0;i〈n/2;i++){temp=a[i];a[i]=a[n—1—i];a[n-1—i]=temp;}for(i=0;i〈n;i++)printf("%d ”,a[i]);return 0;}【练习7-3】求最大值及其下标.输入一个正整数n(1〈n<=10),再输入n个整数,存入数组a中,将先数组a中的这n个数逆序存放,在按顺序输出数组a中的n各元素.试编写相应程序.解答:#include〈stdio.h>int main(void){int i,index,n;int a[10];printf("Enter n:”);scanf(”%d",&n);printf(”Enter %d integrs:”,n);for(i=0;i〈n;i++)scanf("%d",&a[i]);for(i=n—1;i〉=0;i++)printf("%d ”,a[i]);return 0;}【练习7-4】找出不是两个数组共有的元素。
《C语言程序设计基础与实训教程》第7章:数组

/webnew/
7.1.4 一维数组的应用举例
例7.5 将数组中的数按颠倒的顺序重新存放。要求,在操 作时只能借助一个临时存储单元而不能另外开辟数组。 分析:题目要求是按颠倒的顺序重新存放数据,而不是按 逆序输出。 可以使用两个变量i和j,i和j的初值分别为0和9,将a[i] 与a[j]对调,然后i++,j--,接着再将a[i]与a[j]对调。如些 重复操作,直到i>=j时,对调完成。 程序
分析:该数组元素的值是有规律的序列, ( 从 开始算起 开始算起) 分析 : 该数组元素的值是有规律的序列 , 第 i(i从0开始算起) 个 元素的值为: 元素的值为:10+2*i。 。 输出该数组时,由于该数组有30个元素,在一行中输出不太美观, 输出该数组时,由于该数组有 个元素,在一行中输出不太美观, 个元素 所以,这里我们选择每行输出6个元素。 所以,这里我们选择每行输出 个元素。 个元素
/webnew/
7.1.3 一维数组元素的引用
2.一维数组的输入与输出 一维数组的输入与输出 如何给数组元素赋值以及如何将数组元素的值输出是数 组最基本的操作。下面将讨论一维数组元素的输入与输出。 例7.1 定义一个五个元素的字符型数组,通过键盘给每 个元素赋值,并以相反的顺序的输出。 程序1 程序2 从上面的例子可以看出,一个数组中往往往包含较多的 数组元素,相同的赋值或输出操作将被重复多次进行,所以, 一维数组元素的输入与输出一般通过一重循环来实现。
/webnew/
7.1.3 一维数组元素的引用
注意: (1)数组元素的引用方式与数组说明符的形式非常相近,都是 “数组名[表达式]”形式,但两者的意义完全不同。 出现的位置不同。定义数组时,“数组名[表达式]”出现在 定义语句中,表示的是定义了一个名为“数组名”的数组,表达式的值 表示该数组中所包含元素的个数。作为数组元素的引用方式时,“数组 名[表达式]”出现在其它执行语句中,表示是数组中的下标为“表达式” 值的那个元素。 表达式的格式不同。定义数组时,“表达式”必须为常量表 达式。作为数组元素的引用方式时,表达式可以变量、常量或函数构成 的合法C表达式。 (2)在C语言中,起始下标规定为0,最大值应为:数组长度-1。 如果发生了下标越界的现象,可能破坏了其它存储单元的数据,甚至破 坏程序代码。 (3)下标必须是整型表达式,若为小数,则自动取整。如a[2.6] 系统自动默认为a[2]。
第七章 数组

例题1:求10名同学的平均分。7_2.c
main( ) { int a[10]; int i ,sum=0,ave; for (i=0;i<10;i++) scanf("%d",&a[i]); /*类型说明符 数组名[常量表达式]
数组名为a,此数组有10个整型元素*/
/* a[0], a[1], a[2], a[3], a[4]
3. 如果输入多个字符串,则可用空格隔开
char str1[20],str2[20],str3[20]; scanf(“%s%s%s”,str1,str2,str3); 输入为 How are you str1中为“How”, str2 中为“are”, str3中为 “you”。
7.3.3字符数组举例: 从键盘输入一行字符串(<20),求字符串中 小写字母的个数。7-6.c main() {char str[20],len=0,i; 求这个字符串 scanf ("%s",str); 的长度? for (i=0; str[i]!='\0';i++) if (str[i]>='a'&&str[i]<='z') len++; printf ("\n%d",len); }
1 2 3 4 5 6 7 8 9 a[8] 10 a[9]
a[0] a[1] a[2] a[3] a[4]
a[5] a[6] a[7]
2. 不允许对数组的大小作动态定义,即数组的大 小不能是变量。 例如:下面是不合法的: int n; float a[n]; 3. 数组元素的使用与变量是一样的。可以赋值, 也可作各种运算,还可以输入和输出。 例如:a [0]=1 ; a[1]=a[0]型_char、实 型_float)的数据外, C语言还提供了构造类型 的数据,它们有:数组类型、结构体类型、共用 体类型。构造类型数据是由基本类型数据按一定 规则组成的。
C语言基础 第7章 数组

一维数组: float mark[100];
低地址
每个数据元素占用 的字节数,就是基
类型的字节数 一个元素占4个字节
高地址
86.5 mark[0]
92.0 mark[1]
77.5 mark[2]
52.0 mark[3]
.
.
.
.
.
.
94.0
mark[99]
第7章 数组
7.1.2 一维数组的初始化 ❖ 初始化:在定义时指定初始值,编译器把初值
例:int a[10] = {0,1,2,3,4}; 仅前5个元素赋初值,后5个元素自动赋为0。 3、全部元素均初始化为0,不允许简写。 int a[10] = {0,0,0,0,0,0,0,0,0,0}; 不能写成:int a[10]={0*10};
第7章 数组
❖ 不能简写为:
❖ static int a[10] = {0*10};
第7章 数组
❖ 注意: 2)C语言不允许对数组的大小做动态定义, 如:
❖ int n;
❖ scanf("%d",&n);
❖ int a[n]; ❖ 因为在编译时,C编译器根据已知数组大
小分配内存。//只针对全局变量
❖ 说明:
1)数组名:按标识符规则。本例a就是数 组名。
2)整型常量表达式:表示数组元素个数 (数组的长度)。可以是整型常量或符 号常量,不允许用变量。整型常量表达 式在说明数组元素个数的同时也确定了 数组元素下标的范围,下标从0开始~整 型常量表达式-1(注意不是1~整型常量 表达式)。
7.1.3 数组元素的引用
❖ C语言规定,不能引用整个数组,只能逐 个引用元素,元素引用方式:
南昌大学第七章数组答案

A.int a[]="string";B.int a[5]={0,1,2,3,4,5};C.char a="string";D.char a[]={0,1,2,3,4,5};A.1DB.3C.9D.A. B.\"c:\\abc.dat\" C."c:\abc.dat" D."c:\\abc.dat"A. B.C. D.A. B.C. D.A. a[2][4]B. a[lC. a[l+l][0]D. a(2)(1) 确定A. a[0][2*1]B. a[l][3]C. a[4-2][0]D. a[0][4]A. 2B. 3C. 4D.A. 3 5 7B. 3 6 9C. 1 5 9 D 1 4 7A. j*m+iB. i*m+jC. i*m+j-1D. i*m+j+1 确定A. B.C. D.A.1DB.3C.9D.A. B.\"c:\\abc.dat\" C."c:\abc.dat" D."c:\\abc.dat"A. if(s1>s2)B. if(strcmp(s1,s2))C. if(strcmp(s2,s1)>O)D. if(strcmp(s1A. B.C. D.A. int a[3][ ];B. float a(3C. double a[1][4];D. float a(3)(4);A. a[2][4]B. a[lC. a[l+l][0]D. a(2)(1)A. 2B. 3C. 4D.A. 3 5 7B. 3 6 9C. 1 5 9 D 1 4 7A BC DA BC DA BC DA BC DA BD C整体赋值A BC DA BC DA BC DA BC DA BC DA BCD 值A B C DA B C DA B C DA B C DA) abcdefA) abcdA) abcdA) abcdef确定[C] 教师批改:36、给出以下定义:char x[ ]="abcdefg";char y[ ]={…a…,…b…,…c…,…d…,…e…,…f…,…g…};则正确的叙述为A)数组X和数组Y等价B)数组x和数组Y的长度相同C)数组X的长度大于数组Y的长度D)数组X的长度小于数组Y的长度确定[C] 教师批改:37、设有static char str[ ]="Beijing";则执行printf("%d\n", strlen(strcpy(str,"China")));后的输出结果为A) 5 B) 7C) 12 D) 14确定[A] 教师批改:38、请选出以下程序段的输出结果#include<stdio.h>main(){ char sl[10], s2[10], s3[10], s4[10];scanf("%s%s",s1,s2); gets(s3); gets(s4);puts(s1); puts(s2); puts(s3); puts(s4);}输入数据如下:(此处<CR>代表回车符)aaaa bbbb<CR>A bbbbB bbbbC) aaaa bbbbD ccccA BC DA不可以直接用数组名对数组进行整体输入或输出BC数组元素的下标超出所定义的下标范围时,系统将给出DA BC DA B C DA B C DA B C DA BC DA B C D。
第7章 数组 复习

第7章数组1.下列数组声明中,正确的是()。
(a)int a[5]={0}; (b) int a[ ]={0 1 2};(c) int a[5]=0; (d) int a[ ];2.下列数组声明中,正确的是()。
(a)int a[10];(b)int n = 10, a[n];(c)int N =10; int a[N];(d)int n; scanf(" %d ", &n); int a[n];3.已知int a[10];则对a数组元素引用不正确的是()。
(a)a[10] (b) a[3+5] (c) a[10-10](d) a[5]4.以下数组定义中,正确的是()。
(a)int a[2][3] = {1, 2, 3, 4, 5, 6, 7};(b)int a[ ][ ] = {{1, 2, 3},{4, 5, 6},{7, 8,9}};(c)int a[2][ ] = {1, 2, 3, 4, 5, 6};(d)int a[ ][4] = {6};5.若有定义: int a[3] = {0, 1, 2}; 则a[1]的值为()。
(a)0 (b) 1 (c) 2 (d)36.若有定义:inta[3][4]={{1,2},{0},{1,2,3}};则a[1][1]的值为()。
(a)0 (b) {1,2} (c) 1 (d)37.有如下定义int a[ ][3] = {1,2,3,4,5,6,7,8};则数组a 的行数是()。
(a) 2 (b) 3 (c) 4 (d) 无法确定的8.getchar( )函数的功能是从终端输入()。
(a)一个整型变量值(b) 一个实型变量值(c)多个字符(d) 一个字符9.设已定义chars[ ]="\"Name\\Address\023\n";,则字符串所占的字节数是()。
(a)19 (b) 15 (c) 18(d)1410.以下程序段运行后屏幕输出为()。
C语言程序设计数组

课程名称:C语言程序设计 课型与教法:讲授,经过程序扩展,进行对比学习 课时:2课时 讲课题目:
第7章 数组 基本教材:C语言程序设计(高等教育出版社)廖雷主编 教学目旳与要求:经过本章旳学习使学生了解数组旳意义和 基本概念,掌握数组旳定义和元素旳引用,掌握数组在实际 问题处理中旳应用。 教学难点:二维数组概念旳了解 教学要点:数组旳定义和元素旳引用、数据旳排序
例 int data[5a][;1]=7p8r.0in; tf(“%d”,a);
()
data[5]必=1p须0ri;nt/f/f(没o“r%p有(jrl=fi错n\n0t”;f误(j,<a“提[%120]醒d);;\j,t+使”,+a用)[j]时);要注意 () 5
第七章 数组
一维数组
一维数组旳初始化
int a[N]={7,3,2,5,9,1,6,10,4,8}; for(i=0;i<N-1;i++)
for(j=N-1;j>i;j--) if(a[j-1]>a[j]) { k=a[j-1]; a[j-1]=a[j]; a[j]=k; }
printf(“\n”); for(i=0;i<N;i++)
❖数组元素旳存储顺序
原二因维:数内组存例:是按i一nt行维a[序3旳]优[4]先; float b[2][5];
元素个数=行数*列数
例:int a[3]i[n2t]a[3,4];
a[0][0] a[0][1]
0 () a[0][0]
1
a[0][1]
2
a[1][0]
a[1][0] a[1][1] a[2][0] a[2][1]
一维数组旳引用
C语言(第七章数组)

对部分元素赋初值(前面的连续元素)。如: int b[10]={0,1,2,3,4};
表示数组元素的值为:
b[0]=0; b[1]=1; b[2]=2; b[3]=3; b[4]=4; 后5个元素的初值为0。
注意:不能只对不连续部分元素或后面的连续
元素赋初值。 语句: int a[10]={, , , , ,1,2,3,4,5};
main ( ) { int a[2] [3]={{1, 2,3},{4, 5,6}}; int b[3] [2], i, j; printf("array a: \n"); for (i=0; i<=1; i++) { for (j=0; j<=2; j++) { printf("%5d", a[i][j]); b[j][i]=a[i][j]; } printf("\n"); } printf("array b:\n"); for (i=0; i<=2; i++) { for (j=0; j<=1; j++) printf("%5d", b[i]j]); printf("\n"); } }
运行结果如下:
1
1
2
3
5
8
89
13
144
21
133
34
377
55
610
987
1597
1584
4181
6765
四、简单预处理指令
1. 指令格式:
#define 符号常量
2. 指令作用
文本串
用整型表达式替换程序中所有的符号常量。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第七章数组数组是程序设计语言中最基本,最重要的组成部分,本章的习题将从C语言数组的基本概念出发,讨论C 语言数组的特点和使用方法,并通过典型的例题和常见算法研究数组的一般应用,本章的主要内容包括: ●数组基本概念。
包括:数组的定义,数组的类型,数组维数,体积,数组元素和数组下标的概念,数组说明,对数组进行初始化的方法,多维数组中元素的排列次序及初始化等问题。
●字符型数组。
包括:字符型数组与其它数组的区别,字符串及其特点,对字符型数组进行初始化,使用不同的库函数输入输出字符串,对字符串的简单处理(求串长,串复制,串连接,串比较,串反向等) 等。
●数组与函数之间的关系。
包括:将数组作为组与函数之间进行传递等。
●常见的使用数组的算法。
包括:排序算法,查找算法等。
7.1 选择题【7.1】错误的说明语句是。
A)static char word[ ]={‘T’,’u’,’r’,’b’,’o’,’\0’};B)static char word[ ]={“Turbo\0”};C)static char word[ ]=”Turbo\0”;D)static char word[ ]=‘Turbo\0’;【7.2】已知:char s[5],c;register int b;则调用函数scanf的正确语句是。
A)scanf(“%s%c”,s,c);B)scanf(“%d%c,&b,&c);C)scanf(“%d%c”,b,&c);D)scanf(“%s%c”,s,&c);【7.3】要说明一个有10个int元素的数组,应当选择语句。
A) int a [10]; B) int a[2,5];C) int a [ ]; D) int *a[10];【7.4】合法的数组说明语句是。
A)int a[ ]=”string”;B)int a[5]={0,1,2,3,4,5,};C)char a=”string”;D)char a[]={0,1,2,3,4,5,};【7.5】在下述对C语言字符数组的描述中错误的是。
A)字符数组可以存放字符串B)字符数组中的字符串可以进行整体输入输出C)可以在赋值语句中通过赋值运算符“=”对字符数组整体赋值D)字符数组的下标从0开始【7.6】调用strlen(“abcd\0ef\0g”)的返回值为。
A) 4 B) 5 C) 8 D)9【7.7】若有以下语句,则正确的描述是。
static char x[ ]=”12345”;static char y[ ]={‘1’,’2’,’3’,’4’,’5’};A)x数组和y数组的长度相同B)x数组长度大于y数组长度C) x数组长度小于y的数组长度D) x数组等价于y数组【7.8】已知:char str1[10],str2[10]={“books”};则在程序中能够将字符串“books”赋给数组str1的正确语句是。
A)str1 = {“Books”};B)strcpy (str1,str2);C)str1 = str2;D)strcpy (str2,str1);【7.9】以下程序段的输出是。
static char a[ ] = “-12345”;int k=0,symbol, m;if (a[k]==‘+’|| a[k]==‘-’)symbol = (a[k++]==‘+’) ? 1:-1;for (m=0; a[k]>=‘0’&& a[k]<=‘9’;k++)m = m * 10 +a[k]-’0’;printf(“number=&d\n”,symbol*m);A)number = -12345B)number = 12345C)number = -1000D)number = 1000【7.10】若用数组名作为函数调用时的实参,则实际上传递给形参的是。
A)数组首地址B)数组的第一个元素值C) 数组中的全部元素的值C)数组元素的个数【7.11】已知:char str1[20]=”abcde”,str2[20]=”xyz”;则执行语句: printf(“&d”,strlen(strcpy(str1,str2)));输出结果是。
A) 9 B) 3 C) 5 D) 8【7.12】下面关于字符串的说明中,错误的是。
A)char str[7]=”FORTRAN”;B)char str[ ]=”FORTRAN”;C)char *str =”FORTRAN”;D)char str[ ]={‘F’,’0’,’R’,’T’,‘R’,’A’,’N’,’\0’};【7.13】已知:int i,x[3] [3] = {1,2,3,4,5,6,7,8,9};则下面语句的输出结果是。
for (i=0;i<3;i++)printf (“&d”,x[i] [2-i] );A) 1 5 9 B) 1 4 7 C) 3 5 7 D) 3 6 9【7.14】已知:char str[ ]=”ab\n\012\\\””;则执行语句:printf(“&d”,strlen(str));A) 3 B) 4 C) 6 D) 12【7.15】在C语言中,引用数组元素时,其数组下标的数据类型允许是。
A)整型常量B)整型表达式C)整型常量或整型表达式D)任何类型的表达式【7.16】以下对一维整型数组a的正确说明是。
A)int a(10);B)int n=10,a[n];C)int n;scanf(“&d”,&n);int a[n];D)#define SIZE 10int a[SIZE];【7.17】已知:int a[10];则对a数组元素的正确引用是。
A) a[10] B) a[3.5]C) a(5) D) a[10-10]【7.18】在C语言中,一维数组的说明方式为:类型说明符数组名。
A)[常量表达式]B)[整型表达式]C)[整型常量]或[整型表达式]D)[整型变量]【7.19】以下对外部的一维数组a进行正确初始化的语句是。
A)int a[10]=(0,0,0,0,0) ;B)int a[10]={ };C)int a[ ]={0};D)int a[10]={10*1};【7.20】以下对二维数组a的正确说明是。
A)int a[3] [ ];B)float a(3,4);C)double a[1] [4];D)float a(3) (4);【7.21】已知: int a[3][4];则对数组元素引用正确的是。
A) a[2][4] B) [1,3]C) a[1+1][0] D) a(2) (1)【7.22】已知:int a[3][4];则对数组元素的非法引用是。
A) a[0][2*1] B) a[1][3]C) a[4-2][0] D) a[0][4]【7.23】以下能对外部的二维数组a进行正确初始化的语句是。
A)int a[2][ ] = {{1,0,1},{5,2,3}};B)int a[ ][3] = {{1,2,3},{4,5,6}};C)int a[2][4] = {{1,2,3},{4,5},{6}};D)int a[ ][3] = {{1,0,1},{ },{1,1}};【7.24】以下不能对二维数组a进行正确初始化的语句是。
A)int a[2][3] = {0};B)int a[ ][3] = {{1,2},{0}};C)int a[2][3] = {{1,2},{3,4},{5,6}};D)int a[ ][3] = {1,2,3,4,5,6};【7.25】已知:static int a[3][4]={0};则下面正确的叙述是。
A)只有元素a[0][0]可得到初值0B)此说明语句是错误的C)数组a中每个元素都可得到初值,但其值不一定为0D)数组a中每个元素均可得到初值0【7.26】已知在函数的外面有:int a[ ][4]={0,0};则下面叙述中错误的是。
A)数组 a的每个元素都可得到初值0B)二维数组a的第一维大小为1C)因为二维数组a中第二维大小的值除以初值个数的商为1,故数组a的行数为1D)只有元素a[0][0]和a[0][1]可得到初值0,其余元素均得不到初值0【7.27】已知:static int a[3][4];则数组a中各元素。
A)可在程序的运行阶段得到初值0B)可在程序的编译阶段得到初值0C)不能得到确定的初值D)可在程序的编译或运行阶段得到初值0【7.28】以下各组中选项中,均能正确说明二维实型数组a的是。
A)float a[3][4];float a[][4];float a[3][]={{1},{0}};B) float a(3,4);float a[3][4];float a[][]={{0},{0}};C) float a[3][4];float a[][4]={{0},{0}};auto float a[][4]={{0},{0},{0}}E)float a[3][4];float a[3][];float a[][4];【7.29】在C语言中,二维数组元素在内存中的存放顺序是。
A)按行存放 B) 按列存放C) 由用户自己定义 D) 由编译器决定【7.30】对以下说明语句的正确理解是。
int a[10]={6,7,8,9,10};A)将5个初值依次赋给a[1]至a[5]B)将5个初值依次赋给a[0]至a[4]C)将5个初值依次赋给a[6]至a[10]D)因为数组长度与初值的个数不相同,所以此语句不正确【7.31】下列数组说明语句中错误的是。
A)double x[5] = {2.0,4.0,6.0,8.0,10.0};B)int y[5] = {0,1,3,5,7,9};C)char c1[ ] = {‘1’,‘2’,‘3’,‘4’,‘5’};D)char c2[ ] = {‘\x10’, ‘\xa’, ‘\x8’};【7.32】已知:int a[ ][3]={1,2,3,4,5,6,7};则数组a的第一维的大小是。
A) 2 B) 3 C) 4 D)无确定值【7.33】若二维数组a有m列,则在a[i][j]之前的元素各数为。
A) j*m+i B) i*m+jC) i*m+j-1 D) i*m+j+1【7.34】以下正确的语句是。
A)int a[1][4]={1,2,3,4,5};B)float x[3][ ]={{1},{2},{3}};C)long b[2][3]={{1},{1,2},{1,2,3}};D)double y[ ][3]={0};【7.35】下面是对外部变量s的初始化,其中错误的是。