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

##例7.1想输出以下结果,用函数调用实现。
******************
How do you do!
******************

# 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输入两个整数,要求输出其中较大者。要求用函数来找到大数。

(1)先编写max函数:
int max(int x,int y){int z;z=x>y?x:y;return(z);}
(2)在编写主函数
# 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);
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

##例7.4输入两个实数,用一个函数求出它们之和。

# include<stdio.h>
int main()
    {float add(float x,float y);
     float a,b,c;
     printf("Please enter a and b:");
     scanf("%rf,%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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

##例7.5输入4个整数,找出其中最大的数。用函数的嵌套调用来处理。

# 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;
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

##例7.6有5个学生坐在一起,问第5个学生多少岁,他说比第4个学生大2岁。问第4个学生岁数,他说比第3个学生大2岁。问第3个学生,又说比第2个学生大2岁。问第2个学生,说比第1个学生大2岁。最后问第1个学生,他说10岁。请问第5个学生多大。

# include<stdio.h>
int main()
    {int age(int n);
     printf("NO.5,age:%d\n",age(5));
     return 0;
    }
int age(int n)
    {int c;
     if(n==1)
         c=10;
     else
         c=age(n-1)+2;
         return(c);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14

##例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,erro!");
    else if(n==0||n==1)
        f=1;
    else  f=fac(n-1)*n;
    return(f);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

##例7.8Hanoi(汉诺)塔问题。这是一个古典的数学问题,是一个用递归方法解题的典型例子。问题是这样的:古代有一个梵塔,塔内有3个座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 dikes:");
     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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

##例7.9输入10个数,要求输出其中值最大的元素和该元素是第几个数。

# include<stdio.h>
int main()
    {int max(int x,int y);
     int a[10],m,n,i;
     printf("enter 10interger 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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

##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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

##例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 classB 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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

##例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;
            }
       }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

##例7.13有一个3*4的矩阵,求所有元素中的最大值。

# include<stdio.h>
int main()
    {int max_value(int array[ ][4]);
     int a[3][4]={{1,3,5,7},{24,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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

##例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 score:");
     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);
   }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

##例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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14

##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);
    }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

##例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);}
————————————————
版权声明:本文为CSDN博主「倾言.」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_44588388/article/details/87534157

##例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);}
————————————————
版权声明:本文为CSDN博主「倾言.」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_44588388/article/details/87534157

##例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);}
————————————————
版权声明:本文为CSDN博主「倾言.」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_44588388/article/details/87534157

##例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);}

————————————————

谭浩强C语言程序设计第五版第七章例题相关推荐

  1. 谭浩强c语言程序设计第五版---第一章

    5.编写程序,输出平行四边形**** (1) #include<cstdio> int main(){int i,j,k;for(i=0;i<4;i++){//确定形状的关键代码 f ...

  2. 谭浩强《C程序设计第五版》笔记㈠

    Ch1.程序设计和C语言 1.1 什么是计算机程序 1.2 什么是计算机语言 发展阶段 低级语言 机器语言 计算机能够识别和接受的二进制代码称为机器指令,而机器指令的集合就是机器语言. 符号语言 高级 ...

  3. 谭浩强c语言程序设计第四版课后习题:求Sn=a+aa+aaa+aaaa+...n个a ,a是数字 ,n表示a的位数

    题目: 计算 a+aa+aaa+aaaa+aaaaa+-+a-a(n个a)的值,n和a由键盘输入. 思路: 解决这种问题一般是找规律,找出通项.假设a=2 n=3那么就是2+22+222,其中22=2 ...

  4. 谭浩强《C程序设计第五版》笔记⑵

    Ch2 算法----程序的灵魂 2.1程序=算法+数据结构 数据结构:对数据的描述,在程序中要指定用到哪些数据,以及这些数据的类型和数据的组织形式,就是数据结构 对操作的描述,要求计算机进行操作的步骤 ...

  5. 谭浩强C语言程序设计 学习辅导练习题

    谭浩强C语言程序设计 学习辅导练习 第七章 函数 T14 输入N个学生M门课成绩,分别用函数实现下列功能: 1.计算每个学生的平均分 2.计算每门课的平均分 3.找出分数中最高分数所对应的学生和课程 ...

  6. 谭浩强c 语言程序设计

    谭浩强c 语言程序设计  1 C语言概述  1.1  C语言的发展过程  1.2  当代最优秀的程序设计语言  1.3  C语言版本  1.4  C语言的特点  1.5  面向对象的程序设计语言  1 ...

  7. 谭浩强C语言程序设计代码示例第5章(笔记)

    谭浩强C语音程序设计代码示例第四章(新手入门笔记) 第一章包含参考书,在线编译工具,代码,注释等. 遵循共享互助原则 谭浩强C语言程序设计代码示例(1-3章) 谭浩强C语言程序设计代码示例第4章(笔记 ...

  8. 谭浩强C语言程序设计(1-3章代码学习)

    谭浩强C语言程序设计 参考书 C语言学习笔记记录,学习为主,新手小白入门 我所用的C语言在线编译器:lightly在线编译工具 可新建工程 谭浩强C语言程序设计书籍所包含的代码示例加注释说明如下: / ...

  9. 谭浩强C语言程序设计代码示例第6章(笔记)

    谭浩强C语音程序设计代码示例第六章(新手入门笔记) 第一章包含参考书,在线编译工具,代码,注释等. 遵循共享互助原则 谭浩强C语言程序设计代码示例(1-3章) 谭浩强C语言程序设计代码示例第4章(笔记 ...

  10. c语言程序设计曾怡课件,谭浩强 C语言程序设计教程(由曾怡视频修改) 第8章 函数课件...

    谭浩强 C语言程序设计教程(由曾怡视频修改) 第8章 函数课件 一般搬家时转盘与大梁间是固定的,开钻前应根据转盘对井架进行校正,如果中途换转盘,则要在空负荷下根据井架对转盘进行校正 一般搬家时转盘与大 ...

最新文章

  1. Java开发面试题及答案,SpringBoot统一日志处理原理
  2. Android动画效果 translate、scale、alpha、rotate 切换Activity动画 控件位置调整
  3. Mac OS X 修复基本命令失效的问题
  4. 舒服了!淘宝、支付宝等阿里系App取消开屏广告:秒开
  5. 流水线冒险及解决方法
  6. jz2440移植QT5.6【学习笔记】【原创】
  7. jQuery 学习-样式篇(九):jQuery 存储和删除元素私有数据的方法
  8. 服务器系统详细安装步骤
  9. 138529-46-1,Biotin-PEG2-amine可在EDC或HATU存在下与NHS酯或羧酸反应试剂
  10. C#调用触摸屏小键盘
  11. ubuntu18.0安装搜狗输入法无法显示中文
  12. 如何查SCI期刊的影响因子与排名
  13. vega使用方法笔记
  14. 如何让图片变成全景图,vr全景图怎么拍摄和制作
  15. 有些事情,现在不想就晚了
  16. linux shell 未找到命令,未找到linux问题setenv命令(linux issue setenv command not found)
  17. PHP定时任务 - PHP自动定时循环执行任务实例代码
  18. 统计正数和负数的个数然后计算这些数的平均值。
  19. 计算机技术属于全日制工程硕士吗,计算机技术全日制硕士培养方案
  20. Storyboard References

热门文章

  1. 计算机网络技术论文致谢,路由器论文致谢
  2. 5G+4G聚合路由器
  3. 使用AirDrop将文件从iPhone或iPad传送到Mac电脑教程
  4. 解决Glide 4.8.0 圆角与CenterCrop 的冲突问题
  5. Awvs 12.x安装教程
  6. 计算机模拟数学建模,计算机模拟数学建模
  7. CSDN账号被冻结了怎么办
  8. 刘铁猛挨踢人感言:做一个高情商的程序员
  9. 深入浅出MFC 书中源码Frame1(C++11)
  10. Unity在NGUI中默认动态字体Arial字体显示不完整解决方案