第六章 函数和宏定义实验(2)

C程序设计实验报告

实验项目:

1、利用复化梯形公式计算定积分
2、计算Ackerman函数
3、编写计算x的y次幂的递归函数getpower(int x,int y),并在主程序中实现输入输出
4、编写计算学生年龄的递归函数
5、编写递归函数实现Ackman函数

姓名:王锦辉 实验地点: 514实验室 实验时间:2019.5.16


一、实验目的与要求一、实验目的与要求

1.利用复化梯形公式计算定积分
  • 掌握C语言中定义函数的方法;
  • 掌握通过“值传递”调用函数的方法;
2.计算Ackerman函数
  • 掌握递归函数的设计方法;
  • 进一步练习阅读检查与调试修改C程序的方法;
3.编写计算x的y次幂的递归函数getpower(int x,int y),并在主程序中实现输入输出
  • 写出解决该问题的递归算法:
    1616359-20190519184129433-876216744.png
  • 在递归函数中,使用数字1 作为回归条件;
  • 在递归函数中,使用 if_else 语句根据条件的真假来决定是递推还是回归。
4.编写计算学生年龄的递归函数
  • 写出解决该问题的递归算法:
    递归公式如下,根据公式容易写出递归程序。
    1616359-20190519184216331-572092436.png
  • 在递归函数中,使用数字1 作为回归条件;
  • 在递归函数中,使用if_else语句根据条件的真假来决定是递推还是回归。
5.编写递归函数实现Ackman函数
  • 根据递归公式编写递归函数;
  • 在递归函数中,使用if_else语句根据条件的真假来决定是递推还是回归。

二、实验内容

6.4.2.2

1、 问题的简单描述:
(1)编制一个函数sab(a,b,n),其功能为利用复化梯形公式计算定积分
1616359-20190519185139890-1927737703.png
其中n为对区间[a,b]的等分数。要求该函数在一个独立的文件中。
(2)编制一个主函数以及计算被积函数值的函数 f(x),在主函数中调用(1)中的函数sab(a,b,n)计算并输出下列积分值
1616359-20190519185204743-152487869.png
要求主函数与函数f(x)在同一文件中。
(3)编制另一个主函数以及计算被积函数值的函数 f(x),在主函数中调用(1)中的函数sab(a,b,n)计算并输出下列积分值
1616359-20190519185225700-500772342.png
同样要求主函数与函数f(x)在同一文件中。
(4)要求画出模块sab()的流程图。
方法说明:
设定积分为
1616359-20190519185242345-465533077.png
则复化梯形求积公式为
1616359-20190519185257702-1545695506.png
其中h=(b-a)/n,Xk=a+kh。

2.程序流程图:

1616359-20190519192545615-160119677.png

3、实验代码:

#include<stdio.h>
double f(double x);
double sab(double a, double b,int n)
{int k;double h,result,x1,x2,x3=0,t;h=(b-a)/n;x1=f(a);x2=f(b);for (k=1;k<=n-1;k++){t=a+k*h;x3=x3+f(t);}result=h*(x1+x2)/2+h*x3;return result;
}
#include<stdio.h>
#include<math.h>
#include"sab.h"
double f(double x)
{double result;result=x*x*exp(x);return result;
}
main()
{double a,b,result;int n;printf("请输入a,b,n的值:");scanf("%lf%lf%d",&a,&b,&n);result=sab(a,b,n);printf("sab(%lf,%lf,%d)=%f",a,b,n,result);return 0;
}
#include<stdio.h>
#include"sab.h"
double f(double x)
{double result;result=1/(25+x*x);return result;
}
main()
{double a,b,result;int n;printf("请输入a,b,n的值:\n");scanf("%lf%lf%d",&a,&b,&n);result=sab(a,b,n);printf("sab(%lf,%lf,%d)=%lf",a,b,n,result);return 0;
}

附图:
1616359-20190519193547207-1134638972.png
1616359-20190519193555087-615022268.png

6.4.2.3

1、问题的简单描述:具体要求:
(1)根据方法说明,编制计算Ackerman函数的递归函数ack(n,x,y)。
(2)编制一个主函数,由键盘输入n,x,y,调用(1)中的函数ack(n,x,y),计算Ackerman函数。
(3)在主函数中,输入之前要有提示,并检查输入数据的合理性,若输入的数据不合理,则输出错误信息,输出要有文字说明。
(4)输入(n,x,y)=(2,3,1)运行该程序。然后自定义几组数据再运行该程序。
方法说明:
Ackerman函数的定义如下:

n,x,y为非负整数,且
1616359-20190519193911275-1550455382.png

2、流程图:

1616359-20190519194017864-246494919.png

3、实验代码:

#include<stdio.h>
int Ack(int n,int x,int y)
{int a;if(n==0)a=x+1;else if(n==1&&y==0)a=x;else if(n==2&&y==0)   a=0;else if(n==3&&y==0) a=1;else if(n==4&&y==0)   a=2;else if(n!=0&&y!=0)a=Ack(n-1,Ack(n,x,y-1),x);   return a;
}
main()
{int n,x,y,result;printf("Please input n,x,y:");scanf("%d%d%d",&n,&x,&y);if(n<0||x<0||y<0)printf("输入错误,请重新输入!\n"); result=Ack(n,x,y);printf("Ack(%d,%d,%d)=%d\n",n,x,y,result);
}

附图:
1616359-20190519194816588-597089502.png

6.4.3.1

1、问题的简单描述:编写程序,分别从键盘输入数据x和y,计算x的y次幂并输出。

2、流程图:

1616359-20190519195900821-1366362806.png

3、实验代码:

#include<stdio.h>
long getpower(int x,int y)
{if(y==1)return x;elsereturn x*getpower(x,y-1);
}
main()
{int num,power;long answer;printf("输入一个数:");scanf("%d",&num);printf("输入幂次方:");scanf("%d",&power);answer=getpower(num,power);printf("结果是:%ld\n",answer);
}

附图:
1616359-20190519200106676-1223956100.png

6.4.3.2

1.问题的简单描述:用递归方法计算学生的年龄。已知第一位学生年龄最小为10岁,其余学生一个比一个大2岁,求第5位学生的年龄。

2、流程图:

1616359-20190519200156949-1471469574.png

3、实验代码:

#include<stdio.h>
int age(int n)
{int c;if(n==1)c=10;elsec=age(n-1)+2;return c;
}
main()
{int n=5,result;result=age(n);printf("第五位学生的年龄是%d岁",result);
}

附图:
1616359-20190519200406089-207060713.png

6.4.3.3

1、问题的简单描述:
定义递归函数实现下列Ackman函数:
1616359-20190519200458853-2069671721.png
其中m,n为正整数,设计程序求Acm(2,1),Acm(3,2)。

2、流程图:

1616359-20190519200846609-1535111788.png

3、实验代码:

#include<stdio.h>
Acm(int m,int n)
{if(m==0)return n+1;if(n==0)return Acm(m-1,1);if(n>0&&m>0)return Acm(m-1,Acm(m,n-1));
}
int main()
{int f=2,g=1,k=3;printf("Acm(2,1)=%d\nAcm(3,2)=%d",Acm(f,g),Acm(k,f));return 0;
}

附图:
1616359-20190519201012185-886108758.png


三、实验总结

       这次实验有比较简单的题目也有比较难的,但是如果能做到提前预习,并且能把每一小节的知识灵活运用,相对来说我们的学习会更加高效且轻松。

转载于:https://www.cnblogs.com/chenxiqiming/p/10890201.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/277688.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

将控件保存为图片

原文:将控件保存为图片将控件保存为图片 周银辉 这里分别提供win form 和 wpf 两种方式 对于.net 2.0 我们可以简单地利用 BitBlt 函数来实现&#xff0c;非常简单&#xff0c;代码如下&#xff1a; publicstaticclassControlToImageConverter { privateconstInt32 S…

Linux基础命令---get获取ftp文件

get 使用lftp登录ftp服务器之后&#xff0c;可以使用get指令从服务器获取文件。 1、语法 get [-E] [-a] [-c] [-O base] rfile [-o lfile] 2、选项列表 选项 说明 -o 指定输出文件的名字&#xff0c;不指定则使用原来的名字 -c 如果失败&#xff0c;持续获取 -E 获取…

Unity3D学习笔记之二资源导入以及工程管理

本次教程&#xff0c;我们来建立自己的一个工程并导入模型&#xff0c;对模型进行处理。特别说明&#xff1a;这系列教程参考自人人素材翻译组出品的翻译教程《Unity游戏引擎的基础入门视频教程》&#xff0c;本博客中采用的模型和方法均来源于此。这是我浏览过好多教程后觉得讲…

关于cocos creator换装功能的实践与思考

2019独角兽企业重金招聘Python工程师标准>>> 最近在做一个基于cocos creator的微信小游戏&#xff0c;其中一个主要的功能是给角色进行换装。先来说下开发环境&#xff1a; cocos creator1.9.3spine 在官方的文档中只有设置皮肤的接口&#xff0c;实际上是存在可以部…

抖店一件代发实操,干货满满!

我是电商珠珠 没有货源的新手&#xff0c;在店铺刚开始的时候可以搞无货源模式&#xff0c;也就是一件代发&#xff0c;去搬运别人店铺的商品到自己店铺&#xff0c;再去利用信息差去赚取差价。 很多人不知道具体要怎么做&#xff0c;今天我就来给大家讲一讲。 一、入驻 入…

Unity3D学习笔记之三Prefab组件的使用

本次教程&#xff0c;我们来创建一个简单的Prefab组件。教程参考自人人素材翻译组出品的翻译教程《Unity游戏引擎的基础入门视频教程》。说到Prefab&#xff0c;中文翻译为预设体&#xff0c;在Unity官方的书本《Unity4.X从入门到精通》中的解释是&#xff1a;可以理解为是一个…

tomcat闪退解决方案

在这几天&#xff0c;遇到一个Tomcat启动闪退的问题&#xff0c;通过查阅各种资料&#xff0c;算是完美解决。在此分享给朋友们。 首先&#xff0c;确定你的问题在哪里 1.查询错误&#xff1a;winR 输入cmd&#xff0c;进入一般处理程序。通过cd 找到你Tomcat的bin文件夹&#…

NFS4文件锁机制探秘

2019独角兽企业重金招聘Python工程师标准>>> 简介 NFS4实现“租赁锁”。每个锁拥有一样的“租赁期”。客户端的读写操作将刷新“租赁期”。租赁期到期后&#xff0c;锁将被服务器释放。NFS4通过下述“模型”实现对锁的管理&#xff1a; 1) 清晰地划分客户端和服务器…

Stay Hungry Stay Foolish——网络学习平台分享

从1月24号回家也有一阵子了&#xff0c;今天已经是31号&#xff0c;这一个周的中心思想就是一个字&#xff0c;玩。 学生一但远离学校&#xff0c;就会碰到许多学习的阻力&#xff0c;有来自外界的&#xff0c;家里有活要干&#xff0c;有亲戚要访&#xff0c;有同学邀约&…

Unity3D学习笔记之四完善Prefab并添加First Person Controller

好久没学东西并用博客记录了&#xff0c;这个年过的很懒散&#xff0c;慢慢临近开学了&#xff0c;也要提前适应一下&#xff0c;写写东西&#xff0c;这样开学才能更好的进入状态呀&#xff5e;&#xff5e;本次笔记中&#xff0c;我们将来雕琢一个更加完善的Prefab&#xff0…

Unity3D学习笔记之五为Prefab添加材质

本次笔记中&#xff0c;我们将利用unity来创建并使用材质&#xff0c;把材质添加到我们的Prefab中去。这一系列教程以及素材均参考自人人素材翻译组出品的翻译教程《Unity游戏引擎的基础入门视频教程》&#xff0c;下载链接附在第二篇学习笔记中。继续上次笔记中所记录的东西&a…

分布式版本控制系统之Git

Git Git 是目前世界上最先进的分布式版本控制系统&#xff08;没有之一&#xff09;作用 源代码管理为什么要进行源代码管理? 方便多人协同开发方便版本控制Git的诞生 作者是 Linux 之父&#xff1a;Linus Benedict Torvalds当初开发 Git 仅仅是为了辅助 Linux 内核的开发&…

oo第三次博客-JML规格

这三周的作业主要是围绕以JML来约束代码开发&#xff0c;以确保程序的正确性与鲁棒性。 Part 1&#xff1a;三次作业的实现与bug 第一次作业没有任何算法和数据结构上的难度&#xff0c;对于Path和PathContainer的各个方法的实现按照给出的规格复读即可。唯一的难点&#xff08…

Kinect开发笔记之一Kinect详细介绍

毕业设计的课题我选择了结合Kinect和Unity3D开发体感游戏&#xff0c;这是我十分感兴趣的一个课题&#xff0c;所以做好当然责无旁贷。准备再写一系列Kinect的学习笔记&#xff0c;记录自己毕设一步一个脚印的历程。1、Kinect背景介绍众所周知&#xff0c;Kinect是一款集成了很…

获取2个地址之间的距离(高德API)

2019独角兽企业重金招聘Python工程师标准>>> string startLonLat SiteHelper.GetLonLat("大连"); //获取起始地经度纬度 string endLonLat SiteHelper.GetLonLat("沈阳"); //获取目的地经度纬度 int distance SiteHelper.GetDistance(star…

WPF属性学习

一.WPF属性系统 CLR属性 .NET中的属性称为CLR属性 转载于:https://www.cnblogs.com/programme-maker/p/10910166.html

Unity3D学习笔记之六创建更多的Prefab

在写完第五篇后&#xff0c;因为不知名的原因&#xff0c;我突然不能够上传100KB以上的图片在博客中了。等了几天还是这样&#xff0c;所以我用PS把图片的分辨率一张张调低&#xff0c;让图片的大小都在100左右&#xff0c;将积攒了四篇的学习笔记一起发上来&#xff0c;也算弥…

四、构建Node Web程序

---恢复内容开始--- 一、HTTP 服务器的基础知识 1、Node如何向开发者呈现HTTP请求 2、一个用“Hello World”做响应的HTTP服务器 它用了默 认的状态码200&#xff08;表明成功&#xff09;和默认的响应头 3、读取请求头及设定响应头 Node提供了几个修改HTTP响应头的方法&#x…

datagrid 什么时候结束编辑_2020年中考结束后,什么时候出分?什么时候报志愿?...

导语7月19日下午16:00&#xff0c;2020年北京中考正式落下帷幕。考试结束后&#xff0c;很多家长和考生都会长舒一口气&#xff0c;但北京中考在线团队提醒你&#xff0c;现在还不是放松的时刻&#xff0c;中考结束后&#xff0c;还有成绩查询和填报志愿等重要事件等着你。那么…

Unity3D学习笔记之七创建自己的游戏场景

到现在为止我们已经拥有了比较完备的Prefab&#xff0c;已经可以创建宏大的游戏场景&#xff0c;并以第一人称视角在场景中漫游了。这里给大家做个小的示范&#xff0c;建一个小场景大家在创建场景的时候需要自由发挥&#xff0c;做个尽量大的场景出来。这一系列教程以及素材均…