安徽工程大学高级语言程序设计实验报告班级姓名同组者/ 成绩日期2019\11\21 指导教师实验名称函数程序设计一、实验目的1.掌握定义函数的方法。
2.掌握函数实参与形参的对应关系,体会“值传递”的方式。
3.掌握函数的嵌套调用和递归调用的方法。
4.掌握全局变量和局部变量、动态变量和静态变量的概念与使用方法。
5.理解数组作为函数参数的传递方式。
6.理解宏的概念,掌握宏的定义。
7.了解文件包含的概念,掌握其用法。
二、实验内容1.完成程序,求解n!具体要求:输入并完善源程序;对源程序进行编译、连接和运行;写出程序运行结果。
2.计算s=1的k次方+2的k次方+3的k次方+……+N的k次方。
具体要求:输入并完善源程序;对源程序进行编译、连接和运行;写出程序运行结果。
3.写出下面3个程序的输出结果,说明每个程序中的各个x有何不同。
4.阅读程序,理解程序的功能,写出预期结果并上机验证。
5.编程并上机调试运行。
(1)编写一个判断素数的函数,在主函数输入一个整数,输出是否为素数的信息。
(2)输入一个整数,将它逆序输出。
要求定义并调用函数rverse(number),它的功能是返回number的逆序数。
如reverse(12345)的返回值是54321。
(3)用递归法求n阶勒让德多项式的值,递归公式为P(x)=1,n=0;P(x)=x,n=1;P(x)= [(2n-1)*x-Pn-1(x)-(n-1)Pn-2(x)]/n, n>1(4)编写一函数,由实参传递一个字符串,统计此字符串中字母、数字、空格和其他字符的个数,在主函数中输入字符串并输出上述结果。
(5)带参数的宏,使两个参数的值互换,并写出程序,输入两个数作为使用宏时的实参。
输出交换后的两个值。
(6)编写函数,实现两个字符串的连接,在主函数中输入两个字符串并输出连接后的结果(不要使用库函数中的strcat函数)。
(7)请编写函数fun,它的功能是:求出1~1000之内能被7或11整除,但不能同时被7和11整除的所有整数,并将它们放在a所指的数组中,通过n返回这些数的个数,在主函数中输出这些整数,并给出统计的总数。
(8)设有未完成的函数:char GetChar(char c){ char s[]="9038571426";……}字符串s中无序地存储了10个数字字符,没有重复。
函数的功能是:如果字符c不是数字字符,函数原样返回该字符;否则,在s中查找字符C,并返回其在s 中的前一个字符。
如果该字符位于s的最前面(字符'9') ,则返回最后一个字符6'。
如GetChar(4)得到字符'I', GetChar(T)得到字符T。
请完成该函数并在主函数中调用。
*思考题1.请分析不返回值的函数定义与有返回值的函数定义有什么不同,思考这两类函数在实际编程中的作用。
2.请观察本次实验中使用的函数都有几个返回值,当个函数需要有多个返回值时,应该如何处理?3.数组作为函数参数有哪几种方式?这些方式中有没有能解决之前“函数多值返回问题”的方法?4.请分析下面程序的作用。
/*format.h*/#define DIGIT(d) printf("整数输出:%d\n",d)#define FLOAT(f) printf("实数输出:%10.2f\n",f)#define STRING(s) printf("字符串输出:?号s\n",s)/*user's program*/#include<stdio.h>#include<format.h>int main(){int d,num;float f;char s[80];printf("请选择输入格式:1-整数,2-实数,3-字符串: ");scanf("%d",&num);switch(num){ case 1:printf("请输入一个整数: ");scanf("%d",&d);DIGIT(d);break;case 2:printf("请输入一个实数:");scanf("%f",&f);FLOAT(f);break;case 3:printf("请输入一个字符串:");scanf("%s",s);STRING(s);break;default:printf("输入有错误!");}return 0;}三、算法流程图或实验步骤(可根据需要增删、修改)1.#include <stdio.h>f(int n){if (n==1)return(1);elsereturn n*f(n-1);}void main ( ){int x,i;scanf("%d",&i);x=f(i);printf("i!=%d\n",x);}2.#include<stdio.h>long f1(int i,int j){long power=i;int m;for(m=1;m<j;m++)power*=i ;return power;}void main( ){int n,k,m;long sum=0;printf("please input N,k:\n");scanf("%d,%d",&n,&k);for(m=1;m<=n;m++)sum+=f1(m,k);printf("sum is %ld\n",sum); }3.(1)#include<stdio.h>int x=8;void main( ){printf("\nx1=%d",x);{int x=5;printf("\nx2=%d",x);}}(2)#include<stdio.h>int x=8;void main( ){printf("\nx1=%d",x);{int x=5;printf("\nx2=%d",x);}printf("\nx3=%d",x);}(3)#include<stdio.h>void main( ){void sub(void);int i;static int x;int y;i=1;x=8;y=5;printf("i=%d x=%d y=%d\n",i,x,y);sub( );printf("i=%d x=%d y=%d\n",i,x,y); }void sub(void){int i;static int x;i=18;x=20;printf("i=%d x=%d\n",i,x);}4.(1)#include<stdio.h>void sort (int a[]){int i,j,t;for(i=0;i<4;i++)for(j=0;j<4-i;j++)if(a[j]<a[j+1]){t=a[j];a[j]=a[j+1];a[j+1]=t;} }void main( ){int a[5]={5,10,-7,3,7},i;sort(a);for(i=0;i<=4;i++)printf("%4d",a[i]);}结果:10 7 5 3 -7(2)#include<stdio.h>#define SQR(X) X*Xvoid main( ){int a=15,k=1,m=1;a/=SQR(k+m)/SQR(k+m);printf("%d\n",a);}结果:3(1)#include <stdio.h>int prime(int n){int i;for(i=2;i<n;i++)if(n%i==0)break;if(i>=n)return 1;elsereturn 0;}void main(){int n;printf(“Input a integer:”);scanf(“%d”,&n);if(prime(n))printf(“%d is a prime\n”,n);elseprintf(“%d is not a prime\n”,n); }(2)#include <stdio.h>int reverse_num(int n){int m = n%10;int i = n/10;while (i > 0){ int a = i%10; m *= 10; m += a; i /= 10; }return m;}int main( ){ int n = 0;int m = 0;printf("please input a number:\n");scanf("%d", &n);printf("the reverse number is : %d\n",reverse_num(n)); return 0;}(3)#include<stdio.h>double p(int n,double x){if(n==0)return 1;elseif(n==1)return x;elsereturn ((2*n-1)*x-p(n-1,x)-(n-1)*p(n-2,x))/n; }void main(){int n;double x;printf(“Input n and x:\n”);scanf(“%d,%lf”,&n,&x);printf(“%f”,p(n,x));}(4)#include <stdio.h>#include <string.h>int letter=0,digit=0,space=0,other=0;void count(char s[]){int i=0;while(s[i]!=‘\0’){if(s[i]>=‘A’&&s[i]<=‘Z’||s[i]>=‘a’&&s[i]<=‘z’)letter++;elseif(s[i]>=‘0’&&s[i]<=‘9’)digit++;elseif(s[i]==‘‘)space++;else other++;i++;}}void main(){char s[20];printf(“Plese input a string:”);gets(s);count(s);printf(“letter=%d,digit=%d,space=%d,other=%d\n”,letter,digit,space,other); }(5)#include <stdio.h>#define swap(a,b) t=a;a=b;b=t;void main(){int a,b,t;scanf(“%d%d”,&a,&b);swap(a,b);printf(“%d,%d”,a,b);}(6)#include <stdio.h>#include <string.h>void main(){void connect(char s1[],char s2[]);char s1[20],s2[20];printf(“Please input string1:”);gets(s1);printf(“Please input string2:”);gets(s2);connect(s1,s2);printf(“The connected string is:”);puts(s1);}void connect(char s1[],char s2[]){int length1,i,j;length1=strlen(s1);for(i=length1,j=0;s2[j]!=‘\0’;i++,j++) s1[i]=s2[j];s1[i]=‘\0’;}(7)#include<stdio.h>int f(int a[]){int i = 0,n;for(n = 1;n <=1000;n++){if(n%7==0 || n%11==0) //能被7整除或被11整除if(n%77!=0) //不能的同时被7和11整除a[i++]=n; //符合要求的数赋值给数组}return i;}void main(){int a[300],length;length = f(a);for(int i=0; i<length;i++){printf("%-4d",a[i]);if((i+1)%5 == 0) //使输出时每行五个数printf("\n");}printf("\n%d\n", length);}*思考题/*format.h*/#define DIGIT(d) printf("整数输出:%d\n",d)#define FLOAT(f) printf("实数输出:%10.2f\n",f)#define STRING(s) printf("字符串输出:?号s\n",s)/*user's program*/#include<stdio.h>#include<format.h>int main(){int d,num;float f;char s[80];printf("请选择输入格式:1-整数,2-实数,3-字符串: ");scanf("%d",&num);switch(num){ case 1:printf("请输入一个整数: ");scanf("%d",&d);DIGIT(d);break;case 2:printf("请输入一个实数:");scanf("%f",&f);FLOAT(f);break;case 3:printf("请输入一个字符串:");scanf("%s",s);STRING(s);break;default:printf("输入有错误!");}return 0;}四、实验结果及分析1.如第三项程序所示2.如第三项程序所示3. 运行结果:x1=5 /*此处x为全局变量*/x2=3 /*此处x为局部变量*/2) 运行结果:x1=5 /*此处x为全局变量*/x2=3 /*此处x为局部变量*/x3=5 /*此处x为引用外部变量*/3) 此程序中x为静态变量,并且两个变量x所处的域不同运行结果:HELLOi=1 x=10 y=5C PROGRAM1=18 x=20HELLO1=1 x=10 y=54.如第三项程序所示5.如第三项程序所示*思考题1.函数有返回参数和输入参数,是函数最完整的一种形式。