c语言程序设计实验报告函数,c语言程序设计实验报告——函数.doc

本文介绍了一个C语言程序设计实验报告,主要内容包括函数定义与调用、递归方法、全局变量与局部变量的使用等。实验具体涉及素数判断、数字之和计算、整数倍关系确定、组合数计算及最大公约数与最小公倍数的求解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

c语言程序设计实验报告——函数

C语言程序设计实验报告——函数

一、 实验项目名称

函数

二、 实验目的

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的值。对m>n、m

(2)对m>n、m

(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()求最大公约数和最小公倍数,但其值不是由函数返回,而是通过全局变量在函数之间传递的特性将结果反映在主函数中。 四、实验步骤及结果

打开编程软件,分别写入以下代码:

一、

#include

int 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;

else{

for (n=2;n

if (num%n==0)

break;/*若能被整除,说明不是素数,停止循环*/

if (n>=nu

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值