实验目的: <1>了解如何定义函数并使用函数 <2>用函数实现模块化程序设计 <3>学会使用函数递归调用 实验器材: 机房计算机 C语言基础设计教材 实验内容: <1>写一个判断素数的函数 <2>用递归方法求n! <3>有一个3×4的钜阵,求所有元素中的最大值 实验步骤: <1>#include<stdio.h> int main() { int pr(int n); int x; printf("输入需要判断的整数:"); scanf_s("%d", &x); pr(x); printf("\n"); return 0; } int pr(int n) { int i; int a = 0; if(n<2) printf("%d不是素数\n", n); else { for(i=2;i<n;i++) { if (n%i==0) a++; } if(a==0) printf("%d是素数\n", n); else printf("%d不是素数\n", n); } return 0; } <2>#include<stdio.h> int main() {int fac(int n); int n; int y; printf("input an integer number:"); scanf("%d",&n); y=fac(n); printf("%d!=%d\n",n,y); return 0; } int fac(int n) { int f; if(n<0) printf("n<0,data error!"); else if(n==0||n==1) f=1; else f=fac(n-1)*n; return(f); } <3> #include<stdio.h> int main() { int max_vale(int array[][4]); int a[3][4]={{1,3,5,7},{2,4,6,8},{15,17,34,12}}; printf("max is %d\n",max_vale(a)); return 0; } int max_vale(int array[][4]) {int i,j,max; max=array[0][0]; for(i=0;i<3;i++) for(j=0;j<4;j++) if(array[i][j]>max)max=array[i][j]; return(max); } 实验结果(附数据和图表): <1> <2> <3> 实验结果分析及结论: 对于<1>:函数在main函数的后面,需要函数声明 对于<2>:每次调用之后,它的值换回值,又会到达下一个函数处 对于<3>:数组的第二位大小不能省略,函数传递的是地址,单向传递,对于函数中数组的操作,就是对main函数中数组的操作 实验心得体会和建议: 通过此次实验,用函数实现模块化程序设计,对所学的知识有了进一步的充分了解,在过程中,出现了一些问题,不过最后都得以解决。然而通过这些错误,使我对这些知识点更加印象深刻。锻炼自己独立编写程序的能力。弄懂实验原理,并且体会到了实验的操作本事是靠自我亲自动手,亲自开动脑筋,亲自去请教别人才能得到提高的。
|
|
02-05
8900
08-23
2530
“相关推荐”对你有帮助么?
-
非常没帮助
-
没帮助
-
一般
-
有帮助
-
非常有帮助
提交