实验3
task 1
// 生成N个0~99之间的随机整数,并打印输出 #include <stdio.h> #include <stdlib.h> #include <time.h> #define N 5 int main() { int x, n; srand(time(0)); // 以当前系统时间作为随机种子 for(n=1; n<=N; n++) { x = rand() % 100; // 生成一个0~99之间的随机整数 printf("%3d", x); } printf("\n"); return 0; }

task 2
#include <stdio.h> #include <stdlib.h> #include <time.h> int main() { int luckyday,yday,i; srand(time(0)); luckyday = rand() % 31+1; printf("猜猜2021年5月哪一天是你的luckyday\n开始喽,你有三次机会,猜吧(1~31)"); for(i=1;i<4;i++){ scanf("%d",&yday); if (yday>luckyday) printf("你猜的日期晚了\n再猜"); else if(yday<luckyday) printf("你猜的日期早了\n再猜"); else break; } if(i==4) printf("次数用完了,偷偷告诉你,5月你的luckyday是%d号",luckyday); return 0; }

task 3
#include<stdio.h> int main(){ long int s,news=0; int n,i=1; printf("enter a number"); scanf("%ld",&s); do{ n=s%10; s=s/10; if(n%2!=0){ news=news+n*i; i=i*10;} }while(s!=0); printf("new number is%ld\n",news); return 0; }



task 4
// 一元二次方程求解(函数实现方式) // 重复执行, 直到按下Ctrl+Z结束 #include <math.h> #include <stdio.h> // 函数声明 void solve(double a, double b, double c); // 主函数 int main() { double a, b, c; printf("Enter a, b, c: "); while(scanf("%lf%lf%lf", &a, &b, &c) != EOF) { solve(a, b, c); // 函数调用 printf("Enter a, b, c: "); } return 0; } // 函数定义 // 功能:求解一元二次方程,打印输出结果 // 形式参数:a,b,c为一元二次方程系数 void solve(double a, double b, double c) { double x1, x2; double delta, real, imag; if(a == 0) printf("not quadratic equation.\n"); else { delta = b*b - 4*a*c; if(delta >= 0) { x1 = (-b + sqrt(delta)) / (2*a); x2 = (-b - sqrt(delta)) / (2*a); printf("x1 = %.2f, x2 = %.2f\n", x1, x2); } else { real = -b/(2*a); imag = sqrt(-delta) / (2*a); printf("x1 = %.2f + %.2fi, x2 = %.2f - %.2fi\n", real, imag, real, imag); } } }

task 5
#include <stdio.h> double fun(int n); // 函数声明 int main() { int n; double s; printf("Enter n(1~10): "); while(scanf("%d", &n) != EOF) { s = fun(n); // 函数调用 printf("n = %d, s= %f\n\n", n, s); printf("Enter n(1~10): "); } return 0; } // 函数定义 double fun(int n) { double one=1,ans=0,i; for(i=1;i<=n;i++){ ans=ans+one; one=(-1)*one*(1/(i+1)); } return ans; }

task 6
#include<stdio.h> int isPrime(int ); int main(){ int i=0,num,sign,sum=0; for(num=101;num<=200;num++)
{ sign=isPrime(num); if(sign==0){ printf("%d ",num); i++; sum++; if(sum%5==0){ printf("\n"); } } } printf("\n\n100~200间素数个数为%d",i); return 0; } int isPrime (int num){ int a=0,i; for(i=2;i<num;i++){ if(num%i==0) a++; } return a; }

浙公网安备 33010602011771号