第十章
1.
修改程序清单10.7的rain.c程序,用指针进行计算(仍然要声明并初始
化数组)。
/* rain.c -- 计算每年的总降水量、年平均降水量和5年中每月的平均降
水量*/
#include <stdio.h>
#define MONTHS 12 // 一年的月份数
#define YEARS 5 // 年数
int main(void)
{
// 用2010~2014年的降水量数据初始化数组
const float rain[YEARS][MONTHS] =
{
{
4.3, 4.3, 4.3, 3.0, 2.0, 1.2, 0.2, 0.2, 0.4, 2.4, 3.5, 6.6 },
{
8.5, 8.2, 1.2, 1.6, 2.4, 0.0, 5.2, 0.9, 0.3, 0.9, 1.4, 7.3 },
{
9.1, 8.5, 6.7, 4.3, 2.1, 0.8, 0.2, 0.2, 1.1, 2.3, 6.1, 8.4 },
{
7.2, 9.9, 8.4, 3.3, 1.2, 0.8, 0.4, 0.0, 0.6, 1.7, 4.3, 6.2 },
{
7.6, 5.6, 3.8, 2.8, 3.8, 0.2, 0.0, 0.0, 0.0, 1.3, 2.6, 5.2 }
};
int year, month;
float subtot, total;
printf(" YEAR RAINFALL (inches)\n");
for (year = 0, total = 0; year < YEARS; year++) {
// 每一年,各月的降水量总和
for (month = 0, subtot = 0; month < MONTHS; month++)
subtot += *(*(rain+year)+month);
printf("%5d %15.1f\n", 2010 + year, subtot);
total += subtot; // 5年的总降水量
}
printf("\nThe yearly average is %.1f inches.\n\n", total / YEARS);
printf("MONTHLY AVERAGES:\n\n");
printf(" Jan Feb Mar Apr May Jun Jul Aug Sep Oct ");
printf(" Nov Dec\n");
for (month = 0; month < MONTHS; month++) {
//每个月,5年的总降水量
for (year = 0, subtot = 0; year < YEARS; year++)
subtot += *(*(rain+year)+month);
printf("%4.1f ", subtot / YEARS);
}
printf("\n");
return 0;
}
2.
编写一个程序,初始化一个double类型的数组,然后把该数组的内容 拷贝至3个其他数组中(在main()中声明这4个数组)。使用带数组表示法的 函数进行第1份拷贝。使用带指针表示法和指针递增的函数进行第2份拷贝。 把目标数组名、源数组名和待拷贝的元素个数作为前两个函数的参数。第3 个函数以目标数组名、源数组名和指向源数组最后一个元素后面的元素的指 针。也就是说,给定以下声明,则函数调用如下所示:
double source[5] = {1.1, 2.2, 3.3, 4.4, 5.5}; double target1[5];
double target2[5];
double target3[5];
copy_arr(target1, source, 5);
copy_ptr(target2, source, 5);
copy_ptrs(target3, source, source + 5);
#include <stdio.h>
void copy_arr(double ar[], double sou[], int);
void copy_ptr(double ar[], double sou[], int);
void copy_ptrs(double ar[], double sou[], double*ptr);
void pri(double ar[]);//打印数组
int main(void){
double source[5] = {
1.1, 2.2, 3.3, 4.4, 5.5};
double target1[5];
double target2[5];
double target3[5];
copy_arr(target1, source, 5);
copy_ptr(target2, source, 5);
copy_ptrs(target3, source, source + 5);
pri(source);
pri(target1);
pri(target2);
pri(target3);
}
void copy_arr(double ar[], double sou[], int size){
int i;
for (i=0; i<size; i++) {
ar[i]=sou[i];
}
}
void copy_ptr(double ar[], double sou[], int size){
int i;
for (i=0; i<size; i++) {
*(ar+i)=*(sou+i);
}
}
void copy_ptrs(double ar[], double sou[], double*end){
while (sou<end) {
*ar=*sou;
ar++;
sou++;
}
}
void pri(double ar[]){
int i;
for (i=0; i < 5; i++) {
//i< sizeof ar/sizeof ar[0]//本来想用这个限制范围,为啥算出来i<1????
printf("%lf ",ar[i]);
}
printf("\n");
}
3.
编写一个函数,返回储存在int类型数组中的最大值,并在一个简单的程序中测试该函数。
#include <stdio.h>
int main(void){
int max_array(int ar[]);
int arr[5]={
3,5,23,6,9};
printf("数组中最大的数是%d\n",max_array(arr));
}
int max_array(int ar[]){
int max = 0;
int i;
for (i=0; i<5; i++) {
if (max<ar[i]) {
max=ar[i];
}
}
return max;
}
4.
编写一个函数,返回储存在double类型数组中最大值的下标,并在一 个简单的程序中测试该函数。
#include <stdio.h>
int main(void){
int max_array(int ar[]);
int arr[