C++程序设计 第六章 数组
C语言程序设计第06章 数组
1 4 2 3 思考: 0 0 0 0 0 注意:在定义数组时,如果没有为数组变量 1、如果想使一个数组中全部10个元 赋初值,那么就不能省略数组的大小。而且 素值为0,可以怎样写? a数组不初始化,其数组元素为随机值。 1 4 0 2 3 0 0 0 0 100 2、如果想使一个数组中全部 个元 a[0] a[1] a[2] a[3] a[4] a[5] a[6] a[7] a[8] a[9] 素值为1,又该怎样写? 例当对全部数组元素赋初值时,可以省略数组变量的大 char str[ ] = {'a', 'b', 'c', 'd', 'e' }; (5) 则数组str的实际大小为5。 小,此时数组变量的实际大小就是初值列表中表达式的个数。
//超出了数组的大小
(3) 表达式1是第1个数组元素的值,表达式2是第2个 数组元素的值,依此类推; 例 int a[5] = {0, 1, 2, 3, 4}; 经过以上定义和初始化后, a[0] = 0,a[1] = 1,a[2] = 2,a[3] = 3,a[4] = 4。
9
(4) 如果表达式的个数小于数组的大小,则未指定值的 数组元素被赋值为0; 例 int a[10] = {0, 1, 2, 3, 4};
7
<6>C语言中规定数组元素的下标总是从0开始, 例如int a[10];说明整型数组a,有10个元素。这10个
元素是: a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7],a[8], a
[9]; 注意最后一个元素是a[9],而不是a[10],该数 组不存在数组元素a[10]。 并且特别值得注意的是,C编译器对数组下标越 界不作检查。
C语言第六章_数组_2
if (a[i]>a[i+1])
{temp=a[i];a[i]=a[i+1];a[i+1]=temp;14}
#include <stdio.h> main(){ /*对10个整数排序*/
int a[10]={9, 8, 5, 4, 2, 0, 6, 1, 3, 7}, i, k; for (k=1;k<10;k++)
f0=1 (n=0m) ain(){
f1=1
(n=1) int i; long f [20]={1,1};
0 f1n=fn-1f+[0f]n-2 (nfo2r) (i=2;i<20;i++)
1
1
f[1]
2
2
f[2]
f[i]=f[i-2]+f[i-1];
3
3
f[3]
for(i=0;i<20;i++)
4
数组是具有一定顺序的若干同数据类型变 量的集合体。数组要有名称,要有规模。
一.一维数组定义
类型说明符 数组名[常量];
例如:int a[6]; a = = &a[0]
a
内存映象:编译时分配一片连续的内 存空间,数组名为该空间的首地址— —常量地址。
0 a[0]
1 a[1]
2 a[2]
3 a[3]
1
4 a[4]
4
一行一行地存储所有的数组 5
a[0][1] a[0][2] a[0][3] a[1][0] a[1][1]
元素,数组名为该空间的首 6 a[1][2]
地址——地址常量。
7 a[1][3]
8
第6章 数组
第六章数组学习和解题要点1.要学习和掌握C语言的数组问题,首先必须形成这么一个观念,当用数组定义语句:[存储类型] 数据类型数组名[长度];定义一个数组时,表明请求计算机在内存开辟一个大的空间,该空间的名字即为数组名,同时数组名也是该空间在内存的起始地址。
空间的大小由“长度”决定,因此“长度”必须是正整常数明确确定。
即使是N,该N也必须在前面的#define N中明确指明是多少。
该空间可放“长度”个同一类型的数据。
放什么样的数据由数据类型指定。
如:int a[10]; 表明内存地址为a 放10个整数,每个小空间为a[0],a[1],……,a[9]a↘2. 有的想用下面的方法定义任意大小的数组:int n;scanf(“%d”,&n);int a[n];认为从键盘输入一多少大整数给n,则就定义多少大的数组。
这也是错误的。
因为C语言规定,执行语句以后,就不能再出现定义语句。
这种根据程序的需要随时申请空间的称为“动态数据结构”,要用以后的结构类型和指针来解决。
3.可在定义数组的同时,马上就赋初值。
也可由初值的个数决定数组的大小。
如:int a[]={1,2,3,4,5,6,7,8,9,10};4.对数值型的数组操作,只能一个元素一个元素的使用,每一的元素的使用都可以看成一个变量的使用,称之为带下标的变量,而决不允许用数组名。
如 a[i] 当i为多少时即为那一个元素。
在程序中要时时注意现在是对那一个元素操作,如在教材中的“冒泡排序法”和“选择排序法”的程序中要注意现在下标是那一个元素。
注意:定义中的int a[10] 表示共10个元素,而程序中的a[10]表示带下标的变量。
5.二维数组的定义与一维一样,必须有二个正整常数明确确定,我们可以看成多少行和多少列个元素,如果在定义数组的同时赋初值,则第一维的长度可以省略。
无论如何,第二维的长度决不能缺省。
6.对数值型的二维数组,也只能一个元素一个元素的使用,这时一定要二个下标,表示那一行那一列的元素。
C语言 第六章 数组
6
6.1 排序问题
3. 初始化
类型名 数组名[数组长度]={初值表}; 初值表中依次放着数组元素的初值。例如: int a[10]={1,2,3,4,5,6,7,8,9,10}; 静态存储的数组如果没有初始化,系统自动给所有的数组元素赋0。 即 static int b[5]; 等价于 static int b[5]={0,0,0,0,0}; 初始化也可以只针对部分元素,如 static int b[5]={1,2,3}; 只对数组b的前3个元素赋初值,其余元素的初值为0。又如 int f[20]={0,1}; 对数组f的前两个元素赋初值,其余元素的值 不确定。
18
6.2 矩阵中最大值的位置
4. 使用二维数组编程
例7:定义一个3*2的二维数组a,数组元素的值由下式给 出,按矩阵的形式输出a。a[i][j]=i+j(0≤i ≤2, 0≤j ≤1), 见文件p131ex7-6.cpp
i
j
第1次 第2次 第3次 第4次 第5次
第6次
0 0 1 1 2
2
0 1 0 1 0
9
6.1 排序问题
4. 使用一维数组编程
例4:输入一个正整数n(1<n≤10), 再输入n个整数,将它们存入 数组a中。 ① 输出最小值和它所对应的下标。 ② 将最小值与第一个数交换,输 出交换后的n个数。 数组的长度在定义时必须确定, 如果无法确定需要处理的数据 数量,至少也要估计其上限, 并将该上限值作为数组长度。 因为n ≤10,数组长度就取上 限10。此外,如果用变量 index记录最小值对应的下标, 则最小值就是a[index]。 见p124ex7-4.cpp
8
6.1 排序问题
4. 使用一维数组编程
C语言程序设计第六章数组习题及答案
1.以下对一维整型数组a的定义,正确的是_。
(2分)A.int a(10) ;B.int n = 10 , a[n] ;C.int n ;scanf( "%d" , &n ) ;int a[n] ;D.int a[10] ;2.若有定义:int a[10] ;,则对a数组元素的正确引用是_。
(2分)A.a[10]B.a[3.5]C.a(5)D.a[10-10]3.对定义int a[10] = {6 , 7 , 8 , 9 , 10} ; 的正确理解是_。
(2分)A.将5个初值依次赋给a[1]--a[5]B.将5个初值依次赋给a[0]--a[4]C.将5个初值依次赋给a[6]--a[10]D.因为数组长度与初值个数不相同,所以此语句不正确4..若有定义:int a[3][4]; , 则对a数组元素的正确引用是_。
(2分)A.a[3][4]B.a[1,3]C.a[1+1][0]D.a(2)(1)5.以下对二维数组a初始化正确的语句是_。
(2分)A.int a[2][ ]={{0 , 1 , 2}, {3 , 4 , 5}};B.int a[ ][3]={{0, 1, 2}, {3, 4, 5}};C.int a[2][4]={{0, 1 , 2}, {3 , 4}, {5}};D.int a[ ][3]={{0, 1, 2}, { }, {3, 4}};6.对二维数组a进行如下初始化:int a[ ][3]={0 , 1 , 2 , 3 , 4 , 5};则a[1][1]的值是_。
(2分)A.0B.3C.4D.17.下面程序段的运行结果是_。
(2分)#include<stdio.h>int main( ){int i , x[3][3] = {1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9} ;for( i = 0 ; i < 3 ; i++ )printf( "%2d" , x[i][2-i] ) ;return 0 ;}A.1 5 9B.1 4 7C.3 5 7D.3 6 98.以下对数组s的初始化,错误的是_。
C语言程序设计 – 第 06 章课后习题
C语言程序设计– 第六章课后习题电子13-02班王双喜一、选择题1. C语言中一维数组的定义方式为:类型说明符数组名(C)A. [整型常量]B. [整型表达式]C. [整型常量]或[整型常量表达式]D. [常量表达式]2. C语言中引用数组元素时,下标表达式的类型为(C)A. 单精度型B. 双精度型C. 整型D. 指针型3. 若有定义:int a[3][4];,则对a数组元素的非法引用是(D)A. a[0][3*1]B. a[2][3]C. a[1+1][0]D. a[0][4](解释:A、B、C均正确,D看起来引用不太妥当,但其亦有其意义(a[0][4]等价于a[1][0]))4. 若有定义:int a[][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9};,则a数组的第一维大小是(C)A. 1B. 2C. 3D. 4(解释:共9个元素,除以3即可得第一维大小是3;若有余数,则应加1)5. 若有定义:int a[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};,则值为5的表达式是(C)A. a[5]B. a[a[4]]C. a[a[3]]D. a[a[5]]6. 要求定义包含8个int类型元素的一维数组,以下错误的定义语句是(A)A. int N = 8;int a[N]; B. #define N 3while (a[2*N+2];C. int a[] = {0, 1, 2, 3, 4, 5, 6, 7};D. int a[1+7] = {0};(解释:数组的大小必须是整型常量或整型常量表达式)7. 若二维数组a有m列,则在a[i][j]前的元素个数为(A)A. i * m + jB. j * m + iC. i * m + i - 1D. i * m + j - 18. 下面是对数组s的初始化,其中不正确的是(D)A. char s[5] = {"abc"};B. char s[5] = {'a', 'b', 'c'};C. char s[5] = "";D. char s[5] = "abcdef";(解释:D中元素个数太多,算上'\0'共六个,非法)9. 下面程序段的运行结果是(B)char c[] = "\t\v\\\0will\n";printf("%d", strlen(c));A. 14B. 3C. 9D. 字符串中有非法字符,输出值不确定(解释:字符串中第四个是'\0'即结束标志,因此字符串长度是3)10. 判断字符串s1是否等于s2,应当使用(D)A. if (s1 == s2)B. if (s1 = s2)C. if (strcpy(s1, s2))D. if (strcmp(s1, s2) == 0)(解释:对于字符串来讲,其名字的内容是该字符串的起始地址,不能通过比较名字来比较相等,而应该用专用的函数进行逐字符匹配)二、写出程序的执行结果1. 程序一:# include <stdio.h>main(){int a[3][3] = {1, 3, 5, 7, 9, 11, 13, 15, 17};int sum = 0, i, j;for (i = 0; i < 3; i++)for (j = 0; j < 3; j++){a[i][j] = i + j;if (i == j) sum = sum + a[i][j];}printf("sum = %d", sum);}执行结果:打印sum = 6.(解释:a中各个元素的值是其行和列数字之和,sum内保存a中对角线元素之和,即sum = 0 + 2 + 4)2. 程序二:# include <stdio.h>main(){int i, j, row, col, max;int a[3][4] = {{1, 2, 3, 4}, {9, 8, 7, 6}, {-1, -2, 0, 5}};max = a[0][0]; row = 0; col = 0;for (i = 0; i < 3; i++)for (j = 0; j < 4; j++)if (a[i][j] > max){max = a[i][j];row = i;col = j;}printf("max = %d, row = %d, col = %d\n", max, row, col);}执行结果:打印max = 9, row = 1, col = 0.(解释:此程序的功能是逐行逐列扫描元素,总是将最大的元素赋给max,并保存该元素的行数和列数;因此执行完毕后,max是最大的元素(9),row是其行数(1),col是其列数(0))3. 程序三:# include <stdio.h>main(){int a[4][4], i, j, k;for (i = 0; i < 4; i++)for (j = 0; j < 4; j++)a[i][j] = i - j;for (i = 0; i < 4; i++){for (j = 0; j <= i; j++)printf("%4d", a[i][j]);printf("\n");}}执行结果:第一行打印0;第二行打印1 0;第三行打印2 1 0;第四行打印3 2 1 0。
C语言程序设计课件 .ppt
定义C为字符数组,包含10个元素。在赋值以后数组的状态 如图所示: c[0] c[1] c[2] c[3] c[4] c[5] c[6] c[7] c[8] c[9]
I
am
happ y
2020/4/12
24
2、字符数组的初始化
与一般数组的初始化方法类似。
例如char c[ ]={‘I’,’ ’,’a’,’m’,’ ’,’a’,’ ’,’s’,’t’,’u’,’d’,’e’, ’n’,’t’}
a[0] ---------------------- a 00 a 01 a 02 a 03
a
a[1] ---------------------- a 10
a 11
a 12
a 13
a[2] ---------------------- a 20 a 21 a 22 a 23
上面定义的二维数组可以理解为定义了3个一维数组,即 相当于 float a[0][4],a[1][4],a[2][4]
85 555 58 444 44 822 22 280 00 008
第第 第 第结 一二三 四 次次 次 次果
2020/4/12
11
根据流程图写出程序(今设n=10),定义数组长度为11, 本例中对a[0]不用,只用 a[1]到a[10],以符合人们的习惯。
流程图如下:
输入n个数给a[1]到a[n] for j=1 to n-1
for (i=1;i<=10-j;i++) if (a[i]>a[i+1]) {t=a[i];a[i]=a[i+1];a[i+1]=t;}
printf(“the sorted numbers :\n”); for (i=1;i<11;i++)
高树芳C语言程序设计--第六章
[解决方案]设置一个长度为10的类型为整型的数组
存储老题的年龄。
程序代码
5
6.1 一维数组的定义与使用
相关知识: 1.数组的概念 同类型的一组数据。 2.数组的维数 下标的个数 3.一维数组的定义 类型 数组名[常量表达式] 4.一维数组元素的引用 数组名[下标],如:a[1]
6
6.1 一维数组的定义与使用
案例6-10 输出中文大写数字 [案例任务] C语言的字符串知识
[解决方案]使用两维字符数组存储汉字的“壹”
和“拾”等字符串数据。
程序代码
28
6.3字符数组及字符串
相关知识: C语言的字符串知识应用: 数字转换为中国大写汉字数字字符。
29Biblioteka 编写C程序,输入8个整数,将其逆序输出,同 时要输出它们的和。
10
6.2 二维数组的定义与使用
案例6-4 求二维数组中最大数 案例6-5 整数四则运算测试程序
11
6.2 二维数组的定义与使用
案例6-4 求二维数组中最大数
[案例任务]
对于如下3×4的矩阵: 1 2 3 4 6 9 5 4 -10 10 0 -5 编程求出其中的最大值,并输出其所在的行 号和列号。
24
6.3字符数组及字符串
[课堂训练6-4] 统计字符数组中某类字符的个数。设有 一个长度不超过30的字符串s,统计其 中数字字符、大写字母、小写字母、其 它字符的个数。
25
6.3字符数组及字符串
案例6-9字符串处理函数 [案例任务] 从键盘输入两个字符串s1,s2,要求使用 字符串的常用处理函数strlen、strcat、 strcpy、strcmp等。
[解决方案]见流程图。
程序代码
C语言程序设计第四版谭浩强-2022年学习资料
习题5.4统计一串英文字符中的-大写字母、小写字母、数字、空-格、其他字符的个数。-问题扩展:输入一句英文 -统计并-输出每个字母使用的频数和频率
例5.8-Fibonacci数列-问题:如何使用数学中的下标变量-X1X2,…Xn.…形式表示一组相关的数 据
例5.8 Fibonacci数列用数组解决-int i,fibo[40];-fibo[o]=fibo[1] 1;-fori=2;i<40;i++-fibo[i]=fibo[i-1]+fibo[i-2];-for=0 i<40;i++-printf"%10d",fibo[i];-if i+1%5==0printf"\n";
数组的概念-有序数据的集合-用同一名称表示一组相同类型的相-关数据-·用下标区分各个元素-·相当于数学中的 标变量,如-X1,X2,...-a11ya12yy日21y…
维数组的定义-定义:类型说明-数组名[常量]-定义一个数组的名称、类型、元素
一维数组的定义-short int a[3];-a[2]=6;-存储单元-数组元素-00000000000 0110-说明:不能动态定义数组,-存储地址-见P.143说明3
一维数组的定义和引用-例:排序算法-算法演示-•冒泡排序-•选择排序-插入排序-快速排序
冒泡排序-基本思路:依次将数组中相邻两元-素比较,并按要求的顺序交换,从而-将最大/最小的数推至最前或最后 对-余下的数重复上述步骤,最终获得所-需的顺序
冒泡排序-对数组元素a[0]-a[5]升序排序-比较a[5]和a[4],若顺序不符则交换;-比较a[4和a 3],若顺序不符则交换;-比较a[3]和a[2],若顺序不符则交换-比较a[2]和a[1],若顺序不符则交 ;-比较a[1]和a[0],若顺序不符则交换。
c语言教学第6章 数组
§ 6.1 基本概念
整形、实型、字符型都属于基本类型。 其存储特点是:每个变量单独存储,亦称简单变 量。 如:char X=„a‟; int y1=0,y2; y2=X-1; 各变量之间独立存放,没有任何联系。
数组
数组是一种构造的数据类型,在计算机中分配连续 的内存空间。 数组:按序排列的具有相同类型的变量的集合。 用一符号名(数组名)来表示这一数组; 用数组名跟下标来唯一确定数组中的元素;
四、二维数组的初始化 (按行存放) 1、按存放顺序赋值 如:int x[2][3]={1,2,3,4,5,6}; 2、按行赋值 如:int x[2][3]={ {1,2,3},{4,5,6} }; 3、部分赋值 如:static int x[2][3]={1,2,4}; static int x[2][3]={ {1,2,},{4} }; 4、省略第一维长度 如: static int x[][3]={1,2,3,4,5,6,7};
课后 练习:分别定义一个一维数组和一个二维数组并 初始化,找出一维数组和二维数组中的最大元素和最小 元素以及对应的下标。
§6.4
字符数组
定义形式: char 数组名[exp]
一 、字符数组的定义 如:char c[5]; 在C语言中没有专门的字符串 c[0]=„h‟; c[1]=„a‟ 变量,而是将字符串存入字符数 c[2]=„p‟; c[3]=„p‟; 组来处理。 c[4]=„y‟; 即用一个一维数组来存放一 还可以这样定义: 个字符串,每个元素存放一个字 int c[5]; 符。
c[0]=„h‟; c[2]=„p‟; c[4]=„y‟; c[1]=„a‟ c[3]=„p‟;
二、字符数组的初始化
1、按单个元素赋值
static char c[10]={„s‟,„t‟,„o‟,„r‟,„e‟};
C语言程序设计 第6章
#include <stdio.h> #include <stdlib.h> main( ) { int a[10]; /*定义数组*/ int k,j; float ave,s; k=0;s=0.0; for(j=0;j<10;j++) /*用数组存放10个随机整数*/ a[j]=rand()%50; printf("数组中的值:"); for(j=0;j<10;j++) /*输出10个随机整数*/ printf("%6d",a[j]); printf("\n"); for(j=0;j<10;j++) { if(a[j]%2==0) /*如果数组元素的值为偶数*/ {s+=a[j];k++;} /*累加及偶数个数计数*/ } if(k!=0) {ave=s/k; printf("偶数的个数:%d\n偶数的平均植:%f\n",k,ave);} }
(2)定义一个二维数组a[N][5],数组每行存放一名 学生的数据,每行前4列存放学生4门单科成绩,第5列 存放学生的总分。 (3)输入N个学生的单科成绩,存入二维数组a中。 (4)通过变量sum累加计算每位学生的总分,然后 赋值给每行的最后一个元素。 (5)输出数组第5列上的值,即为每个学生的总分。
for(i=0;i<N;i++) { sum=0; for(j=0;j<4;j++) /*计算当前学生的总分*/ sum+=a[i][j]; a[i][4]=sum; } for(i=0;i<N;i++) /*输出每个学生的总分*/ printf("第%d个学生的总分为:%d\n",i+1,a[i][4]); }
C语言 数组ppt
if (a[j] < a[imin]) imin = j;
} if (imin != i) {
temp = a[i]; a[i] = a[imin]; a[imin] = temp; } }
for (i=0; i<10; i++) printf("%3d",a[i]);
第6章 数组
内容提要
数组定义和基本操作; 常用算法:求最大最小值、排序、查找等; 用字符数组存取字符串; 使用字符串处理函数处理字符串
2023/10/17
2
一维数组(Array)的定义
类型 数组名[长度]; – 长度为常量表达式,不可以是变量(但C99提供了动态数组)
例:int a[10]; – 定义一个有10个元素的数组,每个元素的类型均为int – 系统会在内存分配连续的10个int空间给此数组 – a 是数组名,同时也代表着此数组的首地址
31
int a[10]={1,3,5,7,9,12,14,16,18,20}, number; int low = 0, high= 9 ,mid,pos = -1, find = 0
printf("请输入要查找的数:"); scanf("%d",&number);
while (low <= high) {
9
20
#include <stdio.h> int main() {
Bubble sort
int a[10]={93,84,52,46,25,0,66,18,39,70}, i, j, temp;
第06章C语言程序设计教程电子教案
3.可以把2维数组看作是一种特殊的1维数组:它 的元素又是一个1维数 8 | |0 0 | a | 3 4 | + b | 9 10 | = c | 0 0 | |5 6| |11 12| |0 0 | main() //ex60_4.c {static int a[3][2] = {{1,2}, {3,4}, {5,6}}; static int b[3][2] = {{7,8}, {9,10},{11,12}}; static int c[3][2] = {0}; int i, j, k; for(i = 0; i < 3; i++) for(j = 0; j < 2; j++) c[i][j] += a[i][j] + b[i][j]; for(i = 0; i < 3; i++) {for(j = 0; j < 2; j++) printf ("%5d", c[i][j]); printf("\n"); } getchar(); } 8 10 12 14 16 18
运行结果: 123 456
演示
2维数组的定义方式如下:
数据类型 数组名[行常量表达式][列常量表达式][, 数组名2[行常量表达式2][列常量表达式2]……];
1.数组元素在内存中的排列顺序为“按行存放”,即 先顺序存放第一行的元素,再存放第二行,以此类推。
2. 设有一个m*n的数组x,则第i行第j列的元素x[i][j]在 数组中的位置为:i*n+j(注意:行号、列号均从0开始计 数)。
[Return]
6.2 2维数组的定义和引用
6.2.1 6.2.2 6.2.3 6.2.4 2维数组的定义 2维数组元素的引用 2维数组元素的初始化 2维数组应用举例
C语言程序设计课件第06章数组、指针与字符串.ppt
17
指针数组
指 数组的元素是指针类型 针 例:Point *pa[2];
由pa[0],pa[1]两个指针组成
*i_pointer 3i
2000
9
指针变量的初始化
指 语法形式 存储类型 数据类型 *指针名=初始地址; 例:int a , *pa=&a;
针 注意事项
➢用变量地址作为初值时,该变量必须在指针初始化 之前已说明过,且变量类型应与指针类型一致。
➢可以用一个已赋初值的指针去初始化另一个指针变 量。
组 ➢ 数组下标从零开始。 ➢ 下标必须是整形表达式。 ➢ 数组元素可以在定义时直接给出初始值列表。 ➢ 数组元素作函数参数同简单变量作函数参数。 ➢ 数组名作函数参数传递的是地址值。 ➢ 二维数组在内存中按行存放。
4
对象数组
数 声明:
类名 数组名[元素个数];
组 访问方法:
数组名[下标].成员名
与!=的关系运算。
针
– 指向不同数据类型的指针,以及指针与一
般整数变量之间的关系运算是无意义的。
– 指针可以和零之间进行等于或不等于的关
系运算。例如:p==0或p!=0
16
指向数组元素的指针
指 声明与赋值
例:int a[10], *pa;
针 pa=&a[0]; 或 pa=a;
通过指针引用数组元素
C++语言程序设计
第六章 数组、指针与字符串
本章主要内容
数组 指针 动态存储分配 深拷贝与浅拷贝 字符串
C语言程序设计第6章 数组2018版
6.2.2 插入与删除问题
元素的插入和删除是数组的常见操作。由于数组在内存中连续顺 序存储,所以增删元素时需要移动部分元素。
【案例】在递增排列的成绩数组score中插入一个新成绩x,使得插 入后数组仍保持有序。
④③②① 45 61 72 78 80 82 89 92 95
x 81 k
插入元素的算法思想: ①查找待插入数据在数组中应插入的位置k; ②从最后一个元素开始向前直到下标为k的元素依次往后移动
• 定义数组的同时允许为数组的部分或全部元素赋初值;
• 初值一般被组织在花括号中,但字符数组表示的字符 串可例外;
• 初始化格式:
列表中数据以逗号分隔
<类型标识符> <数组名[元素个数]>={<初值列表>};
例如:int a[4]={12 , 4, 8 , 2}; a[2]=?
• 全部元素赋初值时,数组长度可省略。如: int a[5]={0,2,4,6,8}; 也可写为: int a[ ]={0,2,4,6,8}; 作用皆相当于: a[0]=0; a[1]=2; a[2]=4; a[3]=6; a[4]=8; • 部分元素赋初值时,未被赋值元素默认为0(数值 数组)或空字符(字符数组)。如:
一个位置; ③将欲插入的数据x插入第k个元素的位置
要点: 插入前的移动顺序是关键
• 方式1:
从第k个元素开始移动
for(i=k;i<n;i++) score[i+1]=score[i];
①② ③ ④
45 61 72 78 80 82 89 92 95
移后结果:
x 81
k
后面元素皆被覆盖
45 61 72 78 80 82 82 82 82 82
C语言程序设计知识点—第6章 数组
[练习]以下叙述中错误的是( ) A.对于 double 类型数组,不可以直接用数组名对数组进行整体输入或输出 B.数组名代表的是数组所占存储区的首地址,其值不可改变 C.当程序执行中,数组元素的下标超出所定义的下标范围时,系统将给出”下标越界”
[练习]以下程序的输出结果是( )
main()
{
int a[3][3]={{1,2,9},{3,4,8},{5,6,7}},i,s=0;
for (i=0;i<3;i++)
s+=a[i][j]+a[i][3-i-1];
printf(“%d\n”,s);
}
答案:30
[练习]有以下程序:
#include <stdio.h>
puts 函数完全可以由 printf 函数取代。 当需要按一定格式输出时,通常使用 printf
~ 10 ~
C 语言程序设计知识点
主讲教师:杨剑
函数。 字符串示例
#include <stdio.h> void main() {
char line[30]; int i,count = 0; printf("\n 请输入一行字符:\n "); gets(line); i=0; while(line[i] != '\0') { if(line[i] == ' ') count++; i++;
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
C++程序设计第6章数组单个变量只能存放一个数据值。
当程序中要处理一组相同类型、彼此相关的一组数据时,单个变量就不适合了,就需要一种特殊的数据结构来处理,这就是数组。
数组(array)是一种派生类型。
一个数组能同时存放多个数据值,并能对每个数据进行访问。
本章将介绍一维数组、二维数组和字符数组的定义及使用。
6.1 一维数组一个数组(array)是由相同类型的一组变量组成的一个有序集合。
数组中的每个变量称为一个元素(element),所有元素共用一个变量名,就是数组的名字。
数组中的每个元素都有一个序号,称为下标(index)。
访问一个元素就可以用数组名加下标来实现。
数组必须先定义后使用。
6.1.1 一维数组的定义一维数组就是具有一个下标的数组。
定义一个数组有3个要素:类型、名称与大小。
语法格式为:<数据类型> <数组名> [<常量表达式>]其中,<数据类型>确定了该数组的元素的类型,可以是一种基本数据类型,也可以是已定义的某种数据类型。
<数组名>是一个标识符,作为数组变量的名字。
方括号中的<常量表达式>必须是一个正整型数据,其值为元素的个数,即数组的大小或长度。
注意这里的方括号[]表示数组,而不是表示可缺省内容。
例如,下面定义了三个不同类型的数组:int a[5]; //定义了一个int数组afloat b[20]; //定义了一个float数组bdouble c[5]; //定义了一个double数组c对于上面数组a,元素类型为int,a是数组名,方括号中的10表示数组的长度,即该数组包含了5个元素,分别是a[0]、a[1]、a[2]、a[3]、a[4]。
如果一个数组有n个元素,那么数组中元素的下标从0开始到n-1。
具有相同类型的数组可以在一条说明语句中定义。
例如:int a1[5], a2[4]; //同时定义两个整型数组具有相同类型的单个变量和数组也可以在一条语句中定义。
例如:int x, y[20]; //同时定义整型变量和整型数组系统为一个数组分配一块连续的存储空间。
该空间的字节大小为n*sizeof(<元素类型>),其中n为数组的长度。
一个数组的大小必须在定义时确定,可以用一个正整数常量,也可以用命名常量构成的一个表达式。
例如:const int m = 10;int a[m + 10]; //相当于int a[20]一个数组的大小不允许用变量来指定。
一个数组定义之后,其下标的有效范围就确定了。
在定义一个数组时,各下标可以用来表示不同的语义。
例如定义一个数组:float score[8]来表示某学生在某学期的8门课程的成绩,那么score[0]就可以表示高等数学成绩,score[1]可表示英语成绩,score[2]表示C++程序设计课程成绩,等等。
6.1.2 一维数组的初始化在定义一个数组的同时可以给各元素赋予初值。
语法格式为:<类型> <数组名>[<常量表达式>] = {<初值表>};其中<初值表>是用逗号隔开的一组元素值。
值的类型必须与数组元素的类型相兼容。
例如,下面都是合法的初始化。
int a[10]={1,2,3,4,5,6,7,8,9,10}; //初始化数组的所有元素float x[5]={2.1,2.2,2.3,2.4,2.5}; //初始化数组的全部元素int b[10]={1,3,5,7,9}; //初始化前5个元素,其余元素值为0 int c[]={2,4,6,8,10}; //由给定的元素个数确定数组c的大小表6.1列出了上述4个数组初始化后各元素对应的数据值。
表6.1 数组初始化后各元素对应的数据值对数组元素的初始化,说明以下几点。
(1)初始化时,可以对全部元素赋初值,也可以对部分元素赋初值。
若对数组的部分元素赋初值时,未赋值的元素值缺省为0。
(2)若对所有元素赋初值,可以不指定数组的长度,编译器会根据初值表中数据的个数自动确定数组的长度。
(3)在定义数组时,编译器必须知道数组的大小。
因此只有在初始化的数组定义中才能省略大小。
6.1.3 一维数组的使用在定义一个数组之后,就可以使用该数组。
主要用法是通过下标访问各元素。
数组中的每个元素由唯一下标来确定,通过数组名及下标就可以唯一确定数组中的一个元素。
下标可以是表达式,其值必须是整数。
例如下面代码:int a[5], b[2], i, j;a[0] = b[0] = 2; //下标为常量i = 1; j = 3;a[i] = j; //下标为变量,a[j+1] = 8; //下标为表达式a[j] = 3 * a[1];a[b[0]] = a[i] + a[0]; //下标是数组元素的值b[1] = a[2];int h[5];for(i = 0; i < 5; i++)h[i] = i * i; //利用循环为数组元素赋值表6.2给出了执行以上程序段后,三个数组中各元素的值。
表6.2 三个数组元素的值关于数组的使用,说明以下几点:(1)通过下标访问数组元素时,注意下标越界,尤其是使用表达式计算下标。
下标越界访问不会有错误提示,只是访问邻近的内存单元。
如果仅读取元素,结果无法预料。
如果修改了越界元素,就可能导致严重错误。
(2)两个数组之间不能直接赋值,即使类型和长度都相同,也不能直接赋值。
例如:int x[5], y[5] = {2,4,6,10,100};x = y; //语法错误,赋值号左边不是左值要将数组y中的各元素值依次拷贝到数组x中,可用循环语句来实现。
例如:for(int k = 0; k < 5; k++)x[k] = y[k];(3)两个数组名之间不宜使用关系运算符。
即使两者大小内容都相同,用关系运算符来判等也不同。
例如:if (x == y)结果恒为假。
这是因为这个表达式在判断两个数组的存储地址是否一样。
数组名的本质是数组元素的首地址,详见第8章。
6.1.4 一维数组的应用利用数组可存储大量数据,也能用循环方式来访问,就能实现多种问题的求解,下面通过一些实例来说明。
(1) 多项式计算例6-1 有函数y = 5x5-3.2x3+2x2+6.2x-8,任意输入一个x值,求y的值。
要求x和y为float型。
这个函数是一个一元n次多项式。
一般结构为y = a n x n+a n-1x n-1+…+a2x2+a1x+a0,如果按多项式直接计算,会有多次重复计算。
例如,计算x5=x*x*x*x*x,就重复计算了x4=x*x*x*x。
浮点数的乘法计算开销很大,我们应寻求更高效率的解决办法。
对于n次多项式的计算可分解为n个一次式来计算,可避免重复计算。
例如,可将多项式5x5-3.2x3+2x2+6.2x-8分解为((((5x+0)x-3.2)x+2)x+6.2)x-8。
虽然可用一个算术表达式直接实现函数y,但我们希望程序能方便处理任意一个一元n次多项式。
一种办法就是将各个系数依次存放在一个数组中,n次多项式就有n+1个元素,这样只要重复计算n个一次式就可以得到多项式的值。
如果多项式中缺某一项,其系数要用0补齐。
编程如下:#include <iostream.h>void main(void){const int n = 5; //n次多项式float a[n+1] = {5, 0, -3.2, 2, 6.2, -8}, y = a[0], x;cout<<"input x=";cin>>x;for(int i = 0; i < n; i++)y = y * x + a[i+1];cout<<"y="<<y<<endl;}如果要计算另一个一元n次多项式,只需改变n的值和数组a的初始化部分即可。
但是更好的设计是分离出来一个函数来专门计算一元n次多项式的值。
编程如下:#include <iostream.h>float multinomial(int n, float a[], float x){float y = a[0];for(int i = 0; i < n ; i++)y = y*x + a[i+1];return y;}void main(void){const int n = 5;float a[n+1] = {5, 0, -3.2, 2, 6.2, -8}, x;cout<<"input x=";cin>>x;cout<<"y="<<multinomial(n, a, x)<<endl;}上面例子中设计了一个函数来计算一元n次多项式的值。
第1个形参表示n次,第2个形参是一个一维数组,存放n+1个系数。
一维数组作形参不需要说明其长度。
实际上这里要求它的长度应该是n+1。
第3个形参是x的值。
该函数返回一个值作为多项式的值。
例6-2 对一个数组中的n个元素按由小到大的顺序排列,即升序排序。
例如原先数据为int a[6] = {6, 4, 2, 1, 3, 5},排序之后的结果是{1, 2, 3, 4, 5, 6};数据排序方法是常用算法。
排序算法很多,下面介绍选择排序算法和冒泡排序算法。
(2) 选择排序以升序为例,对n个元素进行选择排序,可分为n-1轮。
第1轮,在所有n个元素中选择一个最小元素,放在头一个元素位置,这个过程需要n-1次比较和1次交换。
此时头一个元素a[0]就是最小值,而剩余的n-1个元素(从a[1]到a[n-1])仍然是无序的。
第2轮就对剩余的元素再次选择一个最小的放在次排头位置a[1]。
如此循环n-1轮,就能对n个元素实现升序排列。
每一轮中主要操作就是比较和交换。
下面以int a[6] = {6, 4, 2, 1, 3, 5}为例,说明每一轮的过程。
设外层循环变量i从0循环到4。
在每一轮过程中,设minV alue为最小值, minIndex为最小值的下标。
在每一轮开始时,设头一个元素为最小值,然后依次与后面元素比较。
在每次比较之后,如果发现更小的元素,就更新这两个值。
当比较完成之后,如果最小值不是头一个元素,就将最小值与头一个元素进行交换,使头一个元素成为参与排序的元素的最小值。
第1轮:i = 0;minV alue = 6, minIndex = 0,minV alue = 4, minIndex = 1,minV alue = 2, minIndex = 2,minV alue = 1, minIndex = 3,minV alue = 1, minIndex = 3,a[0]与a[minIndex]交换:a[0]为最小值,不参与下面循环第2轮:i = 1;minV alue = 4, minIndex = 1,minV alue = 2, minIndex = 2,minV alue = 2, minIndex = 2,minV alue = 2, minIndex = 2,a[1]与a[minIndex]交换:前两个有序,不参与下面循环第3轮:i = 2;minV alue = 4, minIndex = 2,minV alue = 4, minIndex = 2minV alue = 3, minIndex = 4a[2]与a[minIndex]交换:前三个有序,不参与下面循环第4轮:i = 3;minV alue = 6, minIndex = 3minV alue = 4, minIndex = 4a[3]与a[minIndex]交换:前四个有序,不参与下面循环第5轮:i = 4;minV alue = 6, minIndex = 4a[4]与a[minIndex]交换:前五个有序,全部升序排列,结束按上面过程编程如下:#include <iostream.h>void main(void){const int n = 6;int a[n] = {6, 4, 2, 1, 3, 5};int i, j, minValue, minIndex, temp;for(i = 0; i < n - 1; i++){ //外层循环控制轮次minValue = a[i]; //假设排头数据最小minIndex = i;for(j = i + 1; j < n; j++){ //内层循环控制每论比较次数if(minValue > a[j]){ //是否找到更小的数minValue = a[j];minIndex = j;}}if(i != minIndex){ //是否需要交换temp = a[i];a[i] = a[minIndex];a[minIndex] = temp;}}for(i = 0; i < n; i++) //输出排序后的数据cout<<a[i]<<'\t';cout<<endl;}选择排序算法中关键是两层嵌套循环和两个条件语句。