用递归的方法求s = k! + n! / m!的值

电玩女神 2023-02-14 13:07 121阅读 0赞
  1. 《程序设计基础实训指导教程-c语言》
  2. ISBN 978-7-03-032846-5
  3. p142
  4. 7.1.2 上级实训内容

【实训内容5】求s = k! + n! / m!的值

  1. #include<stdio.h>
  2. float jiecheng(float);
  3. int main()
  4. {
  5. float s,k,n,m;
  6. char choose;
  7. do
  8. {
  9. printf("分别输入k,n,m的值(以空格隔开):");
  10. scanf("%f%f%f",&k,&n,&m);
  11. getchar();
  12. printf("%.3f",jiecheng(k)+jiecheng(n)/jiecheng(m));
  13. printf("\n继续[y/n]?");
  14. scanf("%c",&choose);
  15. } while (choose=='y'||choose=='Y');
  16. printf("程序结束\n");
  17. }
  18. float jiecheng(float x)
  19. {
  20. int sum;
  21. if(x==1||x==0)
  22. {
  23. sum=1;
  24. }
  25. else
  26. {
  27. sum=x*jiecheng(x-1); //求阶乘的递归调用
  28. }
  29. return sum;
  30. }

在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,121人围观)

还没有评论,来说两句吧...

相关阅读