实验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; }

 

posted on 2021-04-10 23:44  青衿悠子  阅读(83)  评论(3)    收藏  举报