实验三

// 一元二次方程求解
// 重复执行, 直到按Ctrl+D或Ctrl+E结束
//  
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
int main() {
    float a, b, c, x1, x2;
    float delta, real, imag;
    
    printf("Enter a, b, c:  ");
    
    while(scanf("%f%f%f", &a, &b, &c)) {
        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 = %f, x2 = %f\n", x1, x2);
            }
            else {
                real = -b/(2*a);
                imag = sqrt(-delta) / (2*a);
                printf("x1 = %f + %fi, x2 = %f - %fi\n", real, imag, real, imag);
            }
        }
        
        printf("Enter a, b, c:\n");
    }
    system("pause");
    return 0;
} 

//通过循环实现多组输入是因为     while(scanf("%f%f%f", &a, &b, &c)) 
//通过while语句实现多组输入 

// 猜数游戏
// 程序运行时自动生成1~100之间的随机数,提示用户猜
// 如果用户猜的数等于随机数,提示用户猜对了,程序结束
// 否则,如果用户猜的数小于随机数,提示用户低了,用户继续猜
// 如果用户猜的数大于随机数,提示用户高了,用户继续猜 
// 程序循环运行直到用户猜对为止

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main() {
    int guessNumber; // 存放程序运行时生成的1~100之间的随机整数 
    int ans;     // 存放用户猜的数字 
    
    srand((time(0)));  // 以时间函数作为随机种子 
    guessNumber = 1 + rand()%100;  // 生成1~100之间的随机数 
    
    do {
        printf("your guess number is(1~100): ");
        scanf("%d", &ans);
        if(ans < guessNumber)
            printf("%d is lower than the number.\n", ans);
        else if(ans > guessNumber) 
            printf("%d higher then the number.\n", ans); 
    }while(ans != guessNumber);
    
    printf("Congratulations. you hit it~\n");    
    
    system("pause"); // 在devc中运行时,这一行可以去掉
     
    return 0;
} 
//循环运用do...while语句,至少执行一次。 

/* 
编程找出5个整数的最大数和最小数 
《C语言程序设计教程学习指导》p122实验内容(3) 
*/ 

#include <stdio.h>
#include <stdlib.h>
int main() {
    int number, max, min, n;
    
    n=1;
    printf("输入第%d个数: ", n);
    scanf("%d", &number);
    max = number;
    min = number;
    
    while(n<=4) {
        n++;
        printf("输入第%d个数: ", n);
        scanf("%d", &number);    

        if(number>max)
            max = number;
        else if(number<min)
            min = number;
    }
    
    printf("最大数为: %d\n", max);
    printf("最小数为: %d\n", min);
    
    system("pause");
    
    return 0;
} 

#include<stdio.h>
#include<math.h>
int prime(int a);
int prime(int a)
{
    int divisor;
    for(divisor=2;divisor<=sqrt((double)a);divisor++)
    {
        if(a%divisor==0)
        return 0;
    }
    return 1;
}
int main()
{
    int i, n;
    n=0;
    for(i=101;i<=200;i++)
    {
        if(prime(i))
        {
        printf("%6d",i);
        n++;
        if(n%5==0)
           {
            printf("\n");
           }
        }
       
    }
    printf("\n 101~200之间共有%d个素数。",n);
    return 0;
}

#include<stdio.h>
#include<math.h>

int main()
{
    int n,i,sum;
    long int number;
    n=0,sum=0;
    printf("Enter a number:");
    scanf("%ld",&number);

    for(;number!=0;)
    {
    i=number%10;
    number/=10;
        if(i%2!=0)
        {
            n++;
            sum=sum+pow(10,n)*i;
    
        }
        
        
    }
  printf("new number is:%d",sum/10);

    return 0;
 } 
 
 

看到题目想不出算法,思维还有待提高;

对各种语句不太熟练,平时要多加练习。

posted @ 2019-11-15 21:02  天侠  阅读(...)  评论(... 编辑 收藏