C实验1-参考答案

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
下列程序的功能为:通过调用一个判断素数的函数isprime(),验证歌德巴赫猜想:即任何大于2的偶数均可表示为两个素数之和。例如:4=2+2(特例,仅此一个),6=3+3,8=3+5,…。程序要求输入任一偶数,输出6到该数范围内的各个满足条件的组合。
#include<stdio.h>
int isprime(int m)
return x+y;
}
本次实验小结(简介本次内容完成的情况,存在哪些问题,什么原因)
完成情况
成绩等级
评阅人
评阅日期
1
2
3
4
5
6
7
实验1、函数
一、实验目的
1、进一步掌握函数的定义、调用、返回值以及值传递、地址传递的不同;
2、理解并掌握函数的嵌套调用和函数的递归调用;
3、了解全局变量和局部变量、动态变量、静态变量的概念和使用方法;
4、熟悉进入和跳出函数的调试方法
二、实验内容
1、程序填空题(请填写适当的符号或语句,使程序实现其功能)
#include<stdio.h>
int fac(int m)//1
{int f;//2
if(m==0||m==1)//3
f=1;//4
else//5
f=f*fac(m-1);//6
return f;//7
}
main()
{int i,a,b,c;//8
for(i=100;i<=999;i++)//9
【4】; //退出a循环,判别下一个n的组合
}
}
}
2、程序调试题(纠正程序中存在错误,使程序实现其功能)
函数fac()是用户自定义的一个用递归方法求任意整数阶乘的函数,在main函数中通过调用该函数求出一个三位整数n,其每位数字的阶乘之和正好等于该数本身,即x!+y!+z!=n。
例如145=1!+4!+5!。程序中存在错误,请调试程序。
{int i ;
for(i=2;m%i!=0;i++);
return (【1】);
}
main()
{int n,x,a,b;
scanf("%d",&x);
for(n=6;n<=x;n+=2)
for(a=3;a<=n/2;a+=2)
if(【2】)
{b=n-a;
if(【3】)
{printf(“%d=%d+%d”,n,a,b);
5、编程题:编程实现以下功能:在主函数中,由键盘输入10个整数存放在一维数组a中,并调用选择算法函数selectedsort对数组元素进行降序排列。其中的排序算法函数selectedsort调用findmax函数查找数组局部的最大值的下标位置。自定义函数的首部及功能如下:
⑴int findmax(int arr[],int start,int end):该函数用于查找数组中从start到end之间的数组元素中最大值所在的下标位置;
b++;
printf("%d: a=%d, b=%d\n", c, a, b);
}
main()
{ int i;
for (i=1; i<=3; i++)
f(i);
}
7、分析以下程序的运行结果,然后运行程序验证自己的分析是否正确。
#include <stdio.h>
int a=10,b=20;
main( )
{int a=1,c=0;
c=a+b;
printf("%d,",c);
a++;
b++;
mysum(a,b);
{int a=6,b=6;
c=a+b;
printf("%d,",c);
}
printf("%d\n",a+b);
}
int mysum(int x,int y)
{a++;
b++;
printf("%d\n",a+b);
⑵编写主函数,由键盘输入n和m,通过嵌套调用①中的函数完成计算。
⑶输入n和m要给出提示,并检查n和m的合理性,不合理的输入应输出错误信息,并不再进行计算。
4、编程题:用递归方法编写求Fibonacci数列第n项系数的函数fib(n),并且在main函数中调用该函数输出Fibonacci数列从第1项到第n项的系数,每行输出5项,n的值由用户从键盘输入。
{a = i / 100;//10
b = i % 100 / 10;//11
c = i % 10;//12
if(i=fac(a)+fac(b)+fac(c))//13
prwenku.baidu.comntf("%d", i);//14
}
}
3、编程题:编写程序:根据下面的要求,按所给的公式计算并输出结果。
要求:
⑴分别编写一个求阶乘n!的函数fac(n)、一个求组合数函数cnm(n,m);
⑵void selectedsort(int arr[ ],int n):该函数应用选择算法对n个数组元素进行降序排列。
6、分析以下程序的运行结果,然后运行程序验证自己的分析是否正确。
#include <stdio.h>
void f(int c)
{ int a=0;
static int b=0;
a++;
相关文档
最新文档