实验一:
1. 定义一个判断素数的函数isprime(int n),利用该函数输出1000以内的所有素数,每行10个,最后输出一共有多少个素数。(每列对齐)
#include<stdio.h>
int isprime(int i);
int main()
{
int x,i,n,a=0;
printf("请输入多少以内的素数 ",n);
scanf(" %d",&n);
for(i=2;i<=n;i++)
{
x=isprime(i);
if(x!=0)
{
printf(" %4d",x);
a++;
if(a%10==0)
{
printf(" ");
}
}
}
printf(" %d以内共有%d个质素",n,a);
return 0;
}
int isprime(int i)
{
int y;
for(y=2;y<i;y++)
{
if(i%y==0)
return 0;
}
return i;
}
实验二:
2.求两个正整数的最大公约数和最小公倍数。用一个函数gcd(int a,int b)求最大公约数,另一个函数lcm(int a,int b)根据求出的最大公约数求最小公倍数。
#include<stdio.h> int gcd(int a,int b); int lcm(int a,int b); int main() { int a,b,x,y; printf("请输入两个正整数 "); scanf("%d%d",&a,&b); x=gcd(a,b); y=lcm(a,b); printf("最大公约数是%d,最小公倍数是%d",x,y); } gcd(int a,int b) { int gcd,min,i; if(a>b) { min=b; } else { min=a ; } for(i=1;i<=min;i++) { if(a%i==0&&b%i==0) { gcd=i; } } return gcd; } lcm(int a,int b) { int lcm; lcm=a*b/gcd(a,b); return lcm; }
实验三:
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得值: ",x);
scanf("%lf",&x);
y1=fun(2);
y2=fun(x+15);
y3=fun(sin(x));
printf("y1=%.3lf y2=%.3lf y3=%.3lf",y1,y2,y3);
}
double fun(double x)
{
double y;
y=x*x-5*x+4;
return y;
}
实验四:
4.用函数实现:火柴棍等式问题。
#include<stdio.h> int gen(int a); int main() { int b,c,d; for(b=0;b<=9;b++) { for(c=0;c<=9;c++) { d=b+c; if(gen(b)+gen(c)+gen(d)==12) { if(d<10) { printf("%d+%d=%d ",b,c,d); } } } } return 0; } int gen(int a) { int n; switch(a) { case 1:n=2;break; case 7:n=3;break; case 0: case 6: case 9:n=6;break; case 2: case 3: case 5:n=5;break; case 4:n=4;break; case 8:n=7;break; } return n; }
附加题(万年历)
#include<stdio.h> #include<stdlib.h> int isleap(int year); //判断平年、闰年 int days1(int year); //判断某年的天数 int days2(int year,int month); //判断某年某月的天数 int totaldays(int year,int month); //计算某年某月到1900年1月1号的天数 int main() { int year,month,i,x,weekday,maxday; printf("请输入年和月,用空格隔 "); while(1) { scanf("%d%d",&year,&month); if(year<1900||month<1||month>12) { system("cls"); printf("输入错误,重新输入 "); } else break; } weekday=totaldays(year,month)%7; system("cls"); printf(" ***%d年%d月*** ",year,month); printf("====================================================== "); printf("星期日 星期一 星期二 星期三 星期四 星期五 星期六 "); for(i=0;i<weekday;i++) { printf(" "); } maxday=days2(year,month); //days2函数是求每月最大天数 for(x=1;x<=maxday;x++) { printf("%d ",x); if((x+weekday)%7==0) { printf(" "); } } return 0; } int isleap(int year) //判断平年、闰年 { if(year%4==0&&year%100!=0||year%400==0) { return 1; } else { return 0; } } int days1(int year) //判断某年的天数 { int a; a=isleap(year); if(a==1) { return 366; } else { return 365; } } int days2(int year,int month) //判断某年某月的天数 { int a,maxday; a=isleap(year); if(month==1||month==3||month==5||month==7||month==8||month==10||month==12) { maxday=31; } if(month==4||month==6||month==9||month==11) { maxday=30; } if(month==2&&a==0) { maxday=28; } if(month==2&&a==1) { maxday=29; } return maxday; } int totaldays(int year,int month) //计算某年某月到1900年1月1号的天数 { int a,b=0,c,d=0,e; for(a=1900;a<year;a++) { b=b+days1(year); } for(c=1;c<month;c++) { d=d+days2(year,month); } e=b+d; return e; }
知识点总结:
1 函数是构成c语言程序的基本模块,模块化编程最小单位,在程序中出现代码复制是程序质量
不良的表现;
2 函数的格式
函数类型 函数名(形象类型说明)
{
说明
语句
}
3 void表示无返回值,用void时最后的return可以省略
4
实验总结:
1 在程序的开头要吧程序中涉及到的函数全部标明,养成一个好习惯;
2 在调用函数时括号里定义的字符的不用表明什么类型;
3 函数里不能嵌套函数,但函数里可以调用函数;
4 程序开头标明函数时要在语句末尾带分号,在写函数时不用带分号;
5