第七章

第七章 用函数实现模块化程序设计

例7.1 想输出以下的结果,用函数调用实现。
例7.2 输入两个整数,要求输出其中值较大者。要求用函数来找到大数。
例7.3 将例7.2稍作改动,将在max函数中定义的变量z改为float型。函数返回值的类型与指定的函数类型不同,分析其处理方法。
例7.4 输入两个实数,用一个函数求出它们之和。
例7.5 输入四个整数,找出其中最大的数。用函数的嵌套调用来处理。
例7.6 有5个学生坐在一起,问5个学生多少岁,他说比第四个学生大两岁。问第4个学生岁数,他说比第三个学生大两岁。问第3个学生,又说比第2个学生大2岁。问第2个学生,说比第1个学生大两岁。最后问第1个学生,他说是10岁。请问第5个学生多大。
例7.7 用递归方法求n!。
例7.8 汉诺塔问题。这是一个古典的数学问题,是一个用递归方法解题的典型例子。问题是这样的:古代有一梵塔,塔内有三座A,B,C。开始时A座上有64个盘子,盘子大小不等,大的在下,小的在上。有一个老和尚想把这64个盘子从A座移到C座,但规定每次只允许移动一个盘,且在移动过程中在3个座上都始终保持大盘在下,小盘在上。在移动过程中可以利用B座。要求编程序输出移动盘子的步骤。
例7.9 输入10个数,要求输出其中值最大的元素和该数是第几个数。
例7.10 有一个一维数组score,内放10个学生成绩,求平均值。
例7.11 有两个班级,分别有35名和30名学生,调用一个average函数,分别求这两个班的学生的平均成绩。
例7.12 用选择法对数组中10个整数按有小到大排序
例7.13 有一个34的矩阵,求所有元素中的最大值。
例7.14 有一个一维数组,内放10个学生成绩,写一个函数,当主函数调用此函数后能求出平均分、最高分和最低分。
例7.15 若外部变量与局部变量同名,分析结果。
例7.16 考察静态局部变量的值。
例7.17 输出1到5的阶乘值。
例7.18 调用函数,求3个整数中的大者。
例7.19 给定b的值,输入a和m,求a
b和a^m的值。
例7.20 有一个字符串,内有若干个字符,现输入一个字符,要求程序将字符串中该字符删去。用外部函数实现。
例7.1 想输出以下的结果,用函数调用实现。

在这里插入图片描述

#include<stdio.h>
int main()
{ void print_star();
void print_message();
print_star();
print_message();
print_star();
return 0;
}
void print_star()
{
printf("*******************\n");
}
void print_message()
{
printf(" How do you do!\n");

}

运行结果如下:
在这里插入图片描述
例7.2 输入两个整数,要求输出其中值较大者。要求用函数来找到大数。

int max(int x,int y)
{
int z;
z=x>y?x:y;
return (z);
}
#include<stdio.h>
int main()
{
int max(int x,int y);
int a,b,c;
printf("please enter two integer numbers:");
scanf("%d,%d",&a,&b);
c=max(a,b);
printf("max is %d\n",c);
return 0;

}

运行结果如下:
在这里插入图片描述
例7.3 将例7.2稍作改动,将在max函数中定义的变量z改为float型。函数返回值的类型与指定的函数类型不同,分析其处理方法。

#include<stdio.h>
int main()
{
int max(float x,float y);
float a,b;
int c;
scanf("%f,%f",&a,&b);
c=max(a,b);
printf("max is %d\n",c);
return 0;
}
int max(float x,float y)
{ float z;
z=x>y?x:y;
return (z);

}

运行结果如下:
在这里插入图片描述
例7.4 输入两个实数,用一个函数求出它们之和。

#include<stdio.h>
int main()
{
float add(float x,float y);
float a,b,c;
printf("Please enter a and b:");
scanf("%f,%f",&a,&b);
c=add(a,b);
printf("sum is %f\n",c);
return 0;
}
float add(float x,float y)
{float z;
z=x+y;
return (z);

}

运行结果如下:
在这里插入图片描述
例7.5 输入四个整数,找出其中最大的数。用函数的嵌套调用来处理。

#include<stdio.h>
int main()
{int max4(int a,int b,int c,int d);
int a,b,c,d,max;
printf("Please enter 4 interger numbers:");
scanf("%d%d%d%d",&a,&b,&c,&d);
max=max4(a,b,c,d);
printf("max=%d\n",max);
return 0;
}
int max4(int a,int b,int c,int d)
{
int max2(int a,int b);
int m;
m=max2(a,b);
m=max2(m,c);
m=max2(m,d);
return (m);
}
int max2(int a,int b)
{if(a>=b)
return a;
else
return b;

}

运行结果如下:
在这里插入图片描述
例7.6 有5个学生坐在一起,问5个学生多少岁,他说比第四个学生大两岁。问第4个学生岁数,他说比第三个学生大两岁。问第3个学生,又说比第2个学生大2岁。问第2个学生,说比第1个学生大两岁。最后问第1个学生,他说是10岁。请问第5个学生多大。

int age(int n)
{int c;
if(n==1)
c=10;
else
c=age(n-1)+2;
return (c);
}
#include<stdio.h>
int main()
{int age(int n);
printf("NO.5,age:%d\n",age(5));
return 0;

}

运行结果如下:
在这里插入图片描述
例7.7 用递归方法求n!。

#include<stdio.h>
int main()
{
int fac(int n);
int n;
int y;
printf("input an interger number:");
scanf("%d",&n);
y=fac(n);
printf("%d!=%d\n",n,y);
return 0;
}
int fac(int n)
{
int f;
if(n<0)
printf("n<0,data error!");
else if(n==0||n==1)
f=1;
else f=fac(n-1)*n;
return (f);

}

运行结果如下:
在这里插入图片描述
例7.8 汉诺塔问题。这是一个古典的数学问题,是一个用递归方法解题的典型例子。问题是这样的:古代有一梵塔,塔内有三座A,B,C。开始时A座上有64个盘子,盘子大小不等,大的在下,小的在上。有一个老和尚想把这64个盘子从A座移到C座,但规定每次只允许移动一个盘,且在移动过程中在3个座上都始终保持大盘在下,小盘在上。在移动过程中可以利用B座。要求编程序输出移动盘子的步骤。

#include<stdio.h>
int main()
{void hanoi(int n,char one,char two,char three);
int m;
printf("input the number of diskes: ");
scanf("%d",&m);
printf("The step to move %d diskes:\n",m);
hanoi(m,'A','B','C');
}
void hanoi(int n,char one,char two,char three)
{
void move(char x,char y);
if(n==1)
move(one,three);
else{
hanoi(n-1,one,three,two);
move(one,three);
hanoi(n-1,two,one,three);
}
}
void move(char x,char y)
{
printf("%c-->%c\n",x,y);

}

运行结果如下:
在这里插入图片描述
例7.9 输入10个数,要求输出其中值最大的元素和该数是第几个数。

#include<stdio.h>
int main()
{
int max(int x,int y);
int a[10],m,n,i;
printf("enter 10 inteager numbers:");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
printf("\n");
for(i=1,m=a[0],n=0;i<10;i++)
{
if(max(m,a[i])>m)
{m=max(m,a[i]);
n=i;
}
}
printf("The largest number is %d\nit is the %dth number.\n",m,n+1);
}
int max(int x,int y)
{
return(x>y?x:y);

}

运行结果如下:
在这里插入图片描述
例7.10 有一个一维数组score,内放10个学生成绩,求平均值。

#include<stdio.h>
int main()
{
float average(float array[10]);
float score[10],aver;
int i;
printf("input 10 scores:\n");
for(i=0;i<10;i++)
scanf("%f",&score[i]);
printf("\n");
aver=average(score);
printf("average score is %5.2f\n",aver);
return 0;
}
float average(float array[10])
{int i;
float aver,sum=array[0];
for(i=1;i<10;i++)
sum=sum+array[i];
aver=sum/10;
return (aver);

}

运行结果如下:
在这里插入图片描述
例7.11 有两个班级,分别有35名和30名学生,调用一个average函数,分别求这两个班的学生的平均成绩。

#include<stdio.h>
int main()
{
float average(float array[ ],int n);
float score1[5]={98.5,97,91.5,60,55};
float score2[10]={67.5,89.5,99,69.5,77,89.5,76.5,54,60,99.5};
printf("The average of class A is %6.2f\n",average(score1,5));
printf("The average of class B is %6.2f\n",average(score2,10));
return 0;
}
float average(float array[ ],int n)
{int i;
float aver,sum=array[0];
for(i=1;i<n;i++)
sum=sum+array[i];
aver=sum/n;
return (aver);

}

运行结果如下:
在这里插入图片描述
例7.12 用选择法对数组中10个整数按有小到大排序

#include<stdio.h>
int main()
{void sort(int array[ ],int n);
int a[10],i;
printf("enter array:\n");
for(i=0;i<10;i++)
scanf("%d",&a[i]);
sort(a,10);
printf("The sorted array:\n");
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
return 0;
}
void sort(int array[ ],int n)
{int i,j,k,t;
for(i=0;i<n-1;i++)
{k=i;
for(j=i+1;j<n;j++)
if(array[j]<array[k])
k=j;
t=array[k];array[k]=array[i];array[i]=t;
}

}

运行结果如下:
在这里插入图片描述
例7.13 有一个3*4的矩阵,求所有元素中的最大值。

#include<stdio.h>
int main()
{int max_value(int array[ ][4]);
int a[3][4]={{1,3,5,7},{2,4,6,8},{15,17,34,12}};
printf("Max value is %d\n",max_value(a));
return 0;
}
int max_value(int array[ ][4])
{int i,j,max;
max=array[0][0];
for(i=0;i<3;i++)
for(j=0;j<4;j++)
if(array[i][j]>max)max=array[i][j];
return (max);

}

运行结果如下:
在这里插入图片描述
例7.14 有一个一维数组,内放10个学生成绩,写一个函数,当主函数调用此函数后能求出平均分、最高分和最低分。

#include<stdio.h>
float Max=0,Min=0;
int main()
{float average(float array[ ],int n);
float ave,score[10];
int i;
printf("Please enter 10 scores:");
for(i=0;i<10;i++)
scanf("%f",&score[i]);
ave=average(score,10);
printf("max=%6.2f\nmin=%6.2f\naverage=%6.2f\n",Max,Min,ave);
return 0;
}
float average(float array[ ],int n)
{ int i;
float aver,sum=array[0];
Max=Min=array[0];
for(i=1;i<n;i++)
{if(array[i]>Max)Max=array[i];
else if(array[i]<Min)Min=array[i];
sum=sum+array[i];
}
aver=sum/n;
return (aver);

}

运行结果如下:
在这里插入图片描述
例7.15 若外部变量与局部变量同名,分析结果。

#include<stdio.h>
int a=3,b=5;
int main()
{int max(int a,int b);
int a=8;
printf("max=%d\n",max(a,b));
return 0;
}
int max(int a,int b)
{
int c;
c=a>b?a:b;
return (c);

}

运行结果如下:
在这里插入图片描述
例7.16 考察静态局部变量的值。

#include<stdio.h>
int main()
{int f(int);
int a=2,i;
for(i=0;i<3;i++)
printf("%d\n",f(a));
return 0;
}
int f(int a)
{auto int b=0;
static c=3;
b=b+1;
c=c+1;
return (a+b+c);

}

运行结果如下:
在这里插入图片描述
例7.17 输出1到5的阶乘值。

#include<stdio.h>
int main()
{int fac(int n);
int i;
for(i=1;i<=5;i++)
printf("%d!=%d\n",i,fac(i));
return 0;
}
int fac(int n)
{
static int f=1;
f=f*n;
return (f);

}

运行结果如下:
在这里插入图片描述
例7.18 调用函数,求3个整数中的大者。

#include<stdio.h>
int main()
{int max();
extern int A,B,C;
printf("Please enter three integer numbers:");
scanf("%d%d%d",&A,&B,&C);
printf("max is %d\n",max());
return 0;
}
int A,B,C;
int max()
{int m;
m=A>B?A:B;
if(C>m)m=C;
return (m);

}

运行结果如下:
在这里插入图片描述
例7.19 给定b的值,输入a和m,求a*b和a^m的值。

#include<stdio.h>
int A;
int main()
{int power(int);
int b=3,c,d,m;
printf("enter the number a and its power m:\n");
scanf("%d,%d",&A,&m);
c=A*b;
printf("%d*%d=%d\n",A,b,c);
d=power(m);
printf("%d**%d=%d\n",A,m,d);
return 0;
}
extern A;
int power(int n)
{int i,y=1;
for(i=1;i<=n;i++)
y*=A;
return (y);

}

运行结果如下:
在这里插入图片描述
例7.20 有一个字符串,内有若干个字符,现输入一个字符,要求程序将字符串中该字符删去。用外部函数实现。

#include<stdio.h>
int main()
{
extern void enter_string(char str[]);
extern void delete_string(char str[],char ch);
extern void print_string(char str[]);
char c,str[80];
enter_string(str);
scanf("%c",&c);
delete_string(str,c);
print_string(str);
return 0;
}
void enter_string(char str[80])
{
gets(str);
}
void delete_string(char str[],char ch)
{int i,j;
for(i=j=0;str[i]!='\0';i++)
if(str[i]!=ch)
str[j++]=str[i];
str[j]='\0';
}
void print_string(char str[])
{
printf("%s\n",str);

}

运行结果如下:
在这里插入图片描述

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值