C Primer Plus学习 九 数组

        一个数组就是线性存储的一系列相同类型的值,例如10个字符或15个整数。整个数组有一个单一的 名字,单独的项或元素可以使用一个整数索引来进行访问。例如,下列声明:
debts[5] = 32.54; debts[6] = 1.2e+21:

float debts[20];

        声明debts是一个具有20个元素的数组,其中的每个元素都是一个类型为float的值。这个数组的第一 个元素称为debts[0],第二个元素称为debts[l],这样直到debts[19]。注意数组元素的编号是从0而不是1 开始的。每个元素都可以被陚予一个float类型的值。

        例如,您可以使用以下代码:

debts[5] = 32.54; debts[6] = 1.2e+21:

        一个潜在的易犯错误是:出于执行速度的考虑,C并不检査您是否使用了正确的下标。例如,以下都 是错误的代码:
debts[20]=88.32: //没有这个数组元素
debts[33] = 828.12; //没有这个数组元素

        但是编译器并不会发现这样的错误。当程序运行时,这些语句把数据放在可能由其他数据使用的位置 上,因而可能破坏程序的结果甚至使程序崩溃。

        用于标识数组元素的数字称为下标(subscript)、索引(index)或偏移量(offset)。下标必须是整数, 而且像前面提到的那样,下标从0开始。

        数组中的元素在内存中是顺序存储的。如图:


// scores_in.c --使用循环进行数组处理
#include <stdio.h>
#define  SIZE     10
#define  PAR      72
int main(void)
{


int index,score[SIZE];
int sum=0;
float average;


printf("Enter %d golf scores:\n",SIZE);
for (index=0;index<SIZE;index++)
{
scanf("%d",&score[index]);//读入10个分数
}
printf("The scores read in are as follows: \n");
for (index=0;index<SIZE;index++)
{
printf("%5d",score[index]);//验证输入
}
printf("\n");
for(index=0;index<SIZE;index++)
{
sum+=score[index];//求它们的和


}
average=(float)sum/SIZE;
printf("sum of scores%d,average=%.2f\n",sum,average);
printf("that is a handicap of %.0f\n",average-PAR);

return 0;
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值