- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第6章;一 维 数 组;6.1一维数组的定义和引用;
注意:⑴ 数组名定名规则和变量名相同。
⑵ 定义数组时常量表达式可以是常量或符号常量,
不可为变量。
如: # define SiZE 100
char text[SiZE*2+1]
下面的定义是错误的:
int n; char name[n];
⑶ 可以一次同时定义多个同类型数组。
如:int a[5],b[10];
等价于: int a[5];
int b[10]; ;数组中的每个元素可以作为一个变量来访问。; 例1:利用数组输入10个数,再按逆序输出。;利用数组来处理一组相关的同类型变量,可以简化程序。尤其要对变量作相同处理时,数组特别适用于用循环结构来实现的算法。;# include stdio.h
# define NUM 30
void main( )
{ int i;
float x[NUM],sum,average;
sum=0;
printf(“input %d score:\n”,NUM);
for(i=0; iNUM; i++)
{ scanf(“%f”,x[i]);
sum+=x[i];
}
average=sum/NUM;
printf(“average=%.2f\n”,average);
for(i=0;iNUM;i++)
printf(“x[%d]-average=%.2f\n”, i , x[i]-
average);
};数组元素也可以象简单变量一样,在定义的同时进行初始化。;6.1.4 程序举例;例2:用冒泡法对n个数排序(由小到大)。;;;例3:输入6个数,将这6个数按照由小到大的顺序排列后输出,并给出每个输出值原来所对应的次序。;如:a[1]??a[2]
5 3 ;整体思路:;#include stdio.h
void main()
{int a[6],j[6],i,k,x;
for(i=0;i6;i++)
{scanf(%d,a[i]);
j[i]=i;
}
for(i=0;i5;i++)
for(k=0;k5-i;k++)
if(a[k]a[k+1])
{x=a[k];a[k]=a[k+1];a[k+1]=x;
x=j[k];j[k]=j[k+1];j[k+1]=x;
}
;;;(2):输入一数,将它插入到排序后的数组中,使插入后的数组保持原来的次序。;整体思路:;# include stdio.h
void main()
{int a[6]={7,12,14,16,19},x,i,j;
scanf(%d,x);
for(i=0;i ;i++)
if(xa[i])
{for(j= ;ji;j )
a[j]= ;
break;
}
;;(3)输入一个十进制数,将它转换成其它进制数。; for ( ; i=0; i- -)
{
printf(“%c”,digit[next]);
}
printf(“\n”);
}
else
printf(“Base error!\n”);
} ;6.2 二维数组的定义和引用;还可以把二维数组想象成一张二维的表。
例如:float a[3][4]可被看成是一张3行4列的表。;
二维数组的排列顺序是:按行存放。即在内存中先顺序存放第一行的元素,再存放第二行的元素…以此类推。;6.2.2二维数组元素的引用;例1:形成n×n阶方阵,使其对角线上的元素为1,其它元素为0,然后输出该方阵。;# include stdio.h
void main( )
{
int a[30][30], i, j, n;
scanf( “%d”,n); /* 输入方阵阶数, 2≤n ≤30 */
for(i=0;in;i++)
{ for
文档评论(0)