




免费预览已结束,剩余4页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一、 实验项目名称函数二、 实验目的1掌握C函数的定义方法、函数的调用方法、参数说明以及返回值。掌握实参与形参的对应关系以及参数之间的“值传递”的方式;掌握函数的嵌套调用及递归调用的设计方法; 2掌握全局变量和局部变量、动态变量与静态变量的概念和使用方法; 3在编程过程中加深理解函数调用的程序设计思想。 三、实验内容1多模块的程序设计与调试的方法;2函数的定义和调用的方法;3用递归方法进行程序设计。具体内容:1编写一个函数primeNum(int num),它的功能是判别一个数是否为素数。如果num是素数,返回该数;否则返回0值。 要求: (1)在主函数输入一个整数num,调用该函数后,输出num是否是素数的信息。输出格式为:num is prime或num is not prime。 (2)分别输入以下数据:0,1,2,5,9,13,59,121,运行程序并检查结果是否正确。 2编写函数computNum( int num),它的功能是计算任意输入的一个正整数的各位数字之和,结果由函数返回(例如:输入数据是123,返回值为6)。 要求: num由主函数输入,调用该函数后,在主函数内输出结果。 3编写函数,mulNum(int a,int b),它的功能是用来确定a和b是否是整数倍的关系。如果a是b的整数倍,则函数返回值为1,否则函数返回值为0。 要求: (1)在主函数中输入一对数据a和b,调用该函数后,输出结果并加以相应的说明。例如:在主函数中输入:10,5 ,则输出:10 is multiple of 5 (2)分别输入下面几组数据进行函数的正确性测试:1与5、5与5、6与2、6与4、20与4、 37与9等,并对测试信息加以说明。4编写一个计算组合数的函数combinNum(int m,int n)。计算结果由函数返回。 计算组合数的公式是: c(m,n)=m!/(n!*(m-n)!) 要求: (1)从主函数输入m和n的值。对mn、mn、mn和m=n 的情况各取一组数据进行测试,检查程序的正确性。 (3)修改程序,把两个函数分别放在两个程序文件中,作为两个文件进行编译、链接和运行。 5整数a,b的最大公约数是指既能被a整除又能被b整除的最大整数。整数a,b的最小公倍数是指既是a的倍数又是b的倍数的最小整数。编写两个函数,一个函数gcd()的功能是求两个整数的最大公约数,另一个函数mul()的功能是求两个整数的最小公倍数。 要求:(1)两个整数在主函数中输入,并在主函数中输出求得的最大公约数和最小公倍数。 (2)首先将两个整数a和b作为实参传递给函数gcd(),求出的最大公约数后,由函数gcd()带值返回主函数,然后将最大公约数与两个整数a、b一起作为实参传递给函数mul(),以此求出最小公倍数,再由函数mul()带值返回主函数。 (3)修改函数gcd(),函数gcd()采用递归调用的编写方法,两个整数a和b的最大公约数的递归公式是:如果b=0,那么gcd(a,b)=x,否则gcd(a,b)= gcd(b,a%b)。 然后将最大公约数与两个整数a、b一起传递给函数mul(),求出最小公倍数,再由函数mul()将最小公倍数返回主函数。 (4)修改程序,采用全局变量的处理方法,将最大公约数和最小公倍数都设为全局变量,分别用函数gcd()和函数mul()求最大公约数和最小公倍数,但其值不是由函数返回,而是通过全局变量在函数之间传递的特性将结果反映在主函数中。四、实验步骤及结果打开编程软件,分别写入以下代码:一、#includeint PrimeNum(int num);/*声明判断函数*/void main()int i,num;printf(Please input num: );scanf(%d,&num);i=PrimeNum(num);/*调用判断函数*/if (i=0)printf(%d is not prime,num);else printf(%d is prime,num);int PrimeNum(int num)int n,m;if (num=1)/*1不是素数*/m=0;elsefor (n=2;n=num)m=num;elsem=0;return (m);/*返回m*/二、#include int computNum(int num);/*声明函数*/void main()int num,n;printf(请输入不多于10位的整数:);scanf(%d,&num);n=computNum(num);/*调用函数*/printf(%d,n);int computNum(int num)int n,j;n=1;j=0;for (n=1;n11;+n)j=j+num%10;/*将数的每一位数加到j上*/num=num/10;return j;/*直接返回j*/三、#includeint mulNum(int a,int b);/*声明函数*/void main()int a,b,c;printf(Please input a and b:n);scanf(%d,%d,&a,&b);c=mulNum(a,b);/*调用函数*/if (ba)/*大的数是小的数的倍数,所以要判断两个数的大小*/c=b;b=a;a=c;if (c=1)/*两数是倍数关系*/printf(%d is multiple of %d,a,b);else/*不成倍数关系*/printf(%d is not multiple of %d,a,b);int mulNum(int a,int b)int c;if (a%b=0 | b%a=0)/*判断是否能被整除*/c=1;else c=0;return c;四、#include int combinNum(int m,int n);/*声明函数*/void main()int m,n,c;printf(Please input m and n: );scanf(%d,%d,&m,&n);/*输入两个数*/if (mn | m0 | n0)/*判断输入的两个数是否符合数学要求*/printf(Math error!nm cannot smaller than n!nm or n cant smaller than 0!);elsec=combinNum(m,n);/*调用函数*/printf(c(m,n)=m!/(n!*(m-n)!)=%d,c);int combinNum(int m,int n)int accmulNum(int m);/*声明阶乘函数*/int i,j,k,h;i=accmulNum(m);/*调用阶乘函数*/j=accmulNum(n);k=accmulNum(m-n);h=i/(j*k);return h;int accmulNum(int m)/*求数的阶乘的函数*/int i,j;j=1;for (i=1;i=m;+i)j=j*i;return j;修改方案:在文件目录下创建头文件user.h,头文件内有如下内容:int combinNum(int a,int b);int accmulNum(int a);在主程序预处理中加入#include”use.h”,将主程序保存为main.cpp,被调用程序保存为user.cpp,在命令提示符中先后输入cl user.cpp /c、cl main.cpp /c、link main.obj user.obj,得到程序main.exe。五#include int gcd(int a,int b);/*声明求公约数函数*/int mul(int a,int b);/*声明公倍数函数*/void main()int a,b,c,d;printf(请输入a,b:n);scanf(%d,%d,&a,&b);c=gcd(a,b);/*调用公约数函数*/d=mul(a,b);/*调用公倍数函数*/printf(最大公约数是:%d,最小公倍数是:%d,c,d);int gcd(int a,int b)/*公约数函数*/int i,j,k;j= (ab)? b:a;for (i=j;i=1;-i)if (a%i=0 & b%i=0)k=i;break;/*第一次出现能同时被ab整除的是最小公约数*/return k;int mul(int a,int b)int gcd(int a,int b);/*调用公约数函数*/int h,k;k=gcd(a,b);h=a*b/k;/*公约数和公倍数的数学关系*/return h;使用递归调用修改方案:将函数int gcd(int a,int b)的定义改为:int gcd(int a,int b)int c,i;for (;b!=0;)i=a;a=b;b=i%b;c=gcd(a,b);if(b=0)c=a;return c;采用全局变量修改方案#include int k=0,h=0;int gcd(int a,int b);int mul(int a,int b);void main()int a,b,c,d;scanf(%d,%d,&a,&b);gcd(a,b);mul(a,b);printf(最大公约数是:%d,最小公倍数是:%d,k,h);int gcd(int a,int b)int i,j;j= (ab)? b:a;for (i=j;i=1;-i)if (a%i=0 & b%i=0)k=i;break;return k;int mul(int a,int b)int gcd(int a,int b);k=gcd(a,b);h=a*b/k;return h;五、思考题或实验感想1小结函数的定义及调用方法;答:函数的定义的一般形式为:类型标识符 函数名 (形式参数表列)声明部分语句部分函数的调用很灵活,可以由主函数点用其他函数,其他函数也可以互相调用,要调用函数必须要先声明“类型标识符 函数名 ();”然后才能调用。2小结函数中形参和实参的结合规则;答:(1)、在定义函数中指定的形参,在未出现函数调用时,它们不占内存中的存储单元。(2)、实参可
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年海南省统计局下属事业单位考试真题
- 2025【合同范本】农村集体土地租赁合同书
- DB63∕T 2158-2023 高寒高海拔公路隧道防排水设计指南
- DB21∕T 3987-2024 新材料产业专利导航工作技术规程
- 2025商品买卖合同书AA
- 福州成建工程咨询有限公司招聘笔试题库2025
- 2025新版的员工劳动合同范本
- 按摩反射疗法及腧穴知识试卷含答案
- 2025年债权转让合同范本
- 2025国内借款合同协议书模板
- 《计算机网络的原理与实践》课件
- 第三单元 山水梦寻 整体教学设计-2024-2025学年统编版语文八年级上册
- 2025年四川省宜宾五粮液集团招聘笔试参考题库含答案解析
- 铁塔监理流程
- 《社会化网格治理研究的国内外文献综述》5700字
- 稳派教育2025届高考压轴卷英语试卷含解析
- 车间5S检查评分表
- 建筑装饰工程有限公司的简介范文
- 静电复印纸项目质量管理方案
- 高一 人教版 英语 必修一第四单元《Lesson 1 Listening and Speaking》课件
- 中建建筑工程竣工验收指南
评论
0/150
提交评论