1. 定义一个判断素数的函数isprime(int n),利用该函数输出1000以内的所有素数,每行10个,最后输出一共有多少个素数。(每列对齐)
#include<stdio.h> int isprime(int x); int main() { int num=0,n; for(n=2;n<=1000;n++) { if(isprime(n)) { printf("%4d ",n); num++; if(num%10==0) { printf("\n"); } } } printf("一共%d个数\n",num); return 0; } int isprime(int x) { int i,flag=1; for(i=2;i<=x-1;i++) { if(x%i==0) { flag=0; } } if(flag==1) { return 1; } else { return 0; } }
2.求两个正整数的最大公约数和最小公倍数。用一个函数gcd(int a,int b)求最大公约数,另一个函数lcm(int a,int b)根据求出的最大公约数求最小公倍数。
#include<stdio.h> #include<stdlib.h> int gcd(int a,int b); int lcm(int m,int n); int main() { int x,y,temp,b,k; printf("请输入两个数,求最大公约数和最小公倍数:\n"); scanf("%d%d",&x,&y); if(x<=0||y<=0||x==y) { printf("输入错误\n"); exit(0); } if(y>x) { temp=x; x=y; y=temp; } b=gcd(x,y); k=lcm(x,y); printf("最大公约数为%d,最小公倍数为%d\n",b,k); return 0; } int gcd(int a,int b) { int c; do { c=a%b; a=b; b=c; }while(c!=0); return a; } int lcm(int m,int n) { int k; k=m*n/gcd(m,n); return k; }
3.编写一个函数fun(double x)求表达式x2-5x+4的值,x作为参数传给函数。在主函数中调用该函数求下列式子的值:
y1= 22-5*2+4
y2= (x+15)2-5*(x+15)+4
y3= sin2x-5*sinx+4
求y3用数学函数 sin(x) 头文件math.h
求解y2和y3时需要输入x的值。
样例:
y1=-2, x=0.5时,y2=166.75,y3=1.832721
#include<stdio.h> #include<math.h> double fun(double x); int main() { double x,y1,y2,y3; printf("请输入x的值:\n"); scanf("%lf",&x); y1=fun(2); y2=fun(x+15); y3=fun(sin(x)); printf("y1=%.2lf,y2=%.2lf,y3=%lf\n",y1,y2,y3); return 0; } double fun(double x) { double y; y=x*x-5*x+4; return y; }
4.用函数实现:火柴棍等式问题。
#include<stdio.h> int fun(int x); int main() { int a,b,c,sum; for(a=0;a<=9;a++) for(b=0;b<=9;b++) { c=a+b; if(c>9) { continue; } sum=fun(a)+fun(b)+fun(c); if(sum==12) { printf("%d+%d=%d\n",a,b,c); } } return 0; } int fun(int x) { int x1; switch(x) { case 1:x1=2;break; case 4:x1=4;break; case 7:x1=3;break; case 8:x1=7;break; case 2: case 3: case 5:x1=5;break; case 0: case 6: case 9:x1=6;break; } return x1; }
二、知识点总结
1.学会怎么写函数,和怎么调用函数;
2.一定要在开头的地方声明函数,建议刚开始先空出来地方等写完函数后 在将其复制粘贴过去;
3.函数中只能有一个返回值 而且不能有输出;
4.实参就是在主函数中输入的数,形参就是在函数中用到的数(假如主函数你输入的是a,函数中你定义的是x 那么实参就是a,形参就是x);
5.求公约数用到了辗转相除法(两个数中大的除小的,然后再用小的除余数,一直循环知道余数为0,则最后的除数就是最大公约数),最小公倍数(两数相乘除以最大公约数)。
三、实验总结(实验中遇到的问题及解决方法)
1.要在函数前声明变量类型,如果没说 那就是默认的int型的;
2.经常出现的小问题就是英文字母打错来了,括号不匹配,变量不对应,忘记加封号,输出时忘记写输出的值只写了要输出的话。
来源:https://www.cnblogs.com/zj1220/p/6079013.html