5.4.1 数组初始化 C语言允许在说明时对全局数组和静态局部数组初始化,但不能对非静态局部数组初始化。 与其它变量相似,数组初始化的一般形式如下: type-specifier array_name[size1]...[sizen]={value-list}; 数值表是一个由逗号分隔的常量表。这些常量的类型与类型说明相容,第一个常量存入数组的第一个单元,第二个常量存入第二个单元,等等,注意在括号“ }”后要加上分号。 下列中一个1 0元素整型数组被初始化装入数字1到1 0: int i[10]={1,2,3,4,5,6,7,8,9,1 0 } ; 这意味着i [ 0 ]的值为1,而i [ 9 ]的值为1 0。 存放字符串的字符数组的初始化可采用如下简化的形式: char array_name[size] = "string"; 例如,以下代码段将str 初始化为” h e l l o”。 char str[6] = "hello"; 上面代码产生和下面代码相同的结果: char str[6]={'h',' e ' ,' l ' ,' l ' ,' o ' ,' / o ' } ; 因为C语言中的字符串都以空( N U L L)字符为终结,故要确认定义的数组足够长以存放 空字符。这就是为什么h e l l o只有5个字符,而str 要有6个字符长的原因。使用字符串常量时, 编译程序自动地在末尾加上空字符。 多维数组初始化的方法与一维数组相同,例如,下式将s q r s初始化为从1到1 0及它们各自 的平方数。 int sqrs[10][2]={ 1,1, 2,4, 3,9, 4,1 6 , 5,2 5 , 6,3 6, 7,4 9 , 8,6 4 , 9,8 1, 1 0,1 0 0 , } ; 5.4.2 变长数组的初始化 设想用数组初始化的方法建立一个如下错误信息表: char e1[12] = "read error/n"; char e2[13] = "write error/n"; char e3[18] = "cannot open file/n"; 可以想象,如果用手工去计算每一条信息的字符数以确定数组的长度是何等的麻烦。利 用变长数组初始化的方法可以使C自动地计算数组的长度。变长数组初始化就是使C编译程序 自动建立一个不指明长度的足够大的数组以存放初始化数据。使用这种方法,以上信息表变 为: char e1[] = "read error/n"; char e2[] = "write error/n"; char e3[] = "cannot open file/n"; 给定上面的初始化,下面的语句printf("%s has length %d/,n"e2 ,si z e o f ( e 2 ) ) ; 将打印出: write error has length 13 除了减少麻烦外,应用变长数组初始化使程序员可以修改任何信息,而不必担心随时可 能发生的计算错误。 变长数组初始化的方法不仅仅限于一维数组。但在对多维数组初始化时,必须指明除了 第一维以外其它各维的长度,以使编译程序能够正确地检索数组。其方法与数组形式参数的 说明类似。这样就可以建立变长表,而编译程序自动地为它们分配存储空间。例如,下面用 变长数组初始化的方法定义数组s q r s : int sqrs[ ][2]={ 1,1, 2,4, 3,9, 4,1 6, 5,2 5, 6,3 6, 7,4 9, 8,6 4, 9,8 1, 1 0,1 0 0 } ; 相对定长数组的初始化而言,这种说明的优点在于可以在不改变数组各维长度的情况下, 随时增加或缩短表的长度。 5.5 应用程序举例 [例5-6] 为比赛选手评分。 计算方法:从1 0名评委的评分中扣除一个最高分,扣除一个最低分,然后统计总分,并 除以8,最后得到这个选手的最后得分(打分采用百分制)。 # i n c l u d e < s t d i o . h > m a i n ( ) { int score[10]; / * 1 0 个评委的成绩* / float mark; /最*后得分*/ int i; int max = -1; / *最高分* / int min = 101; /*最低分* / int sum = 0; /*10个评委的总和* / f o r ( i = 0 ; i < 1 0 ; i + + ) { printf("Please Enter the Score of No. ,%di"+ 1 ) ; s c a n f ( " % d / n " ,& s c o r e [ i ] ) ; s u m = s u m + s c o r e [ i ] ; } f o r ( i = 0 ; i < 1 0 ; i + + ) { i f ( s c o r e [ i ] > m a x ) m a x = s c o r e [ i ] ; } f o r ( i = 0 ; i < 1 0 ; i + + ) { i f ( s c o r e [ i ] < m i n ) m i n = s c o r e [ i ] ; } m a r k = ( s u m - m i n - m a x ) / 8 . 0 ; printf("The mark of the player is %.1f,/nm"a r k ) ; } <  
说明:本教程来源互联网或网友上传或出版商,仅为学习研究或媒体推广,wanshiok.com不保证资料的完整性。
1/2 1 2 下一页 尾页 |