PTA实验六:第5章 循环结构-2

7-1 求奇数分之一序列前N项和  分数 20

本题要求编写程序,计算序列 1 + 1/3 + 1/5 + ... 的前N项之和。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。

输入样例:

23

输出样例:

sum = 2.549541

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main(){
    double N, i, n, sum;
    scanf("%lf", &N);
    for(i=1, sum = 0;i<=N; n=1/(2*i-1), sum+=n, i++);
    printf("sum = %.6lf", sum);
    return 0;
}

7-2 找出最小值  分数 20

本题要求编写程序,找出给定一系列整数中的最小值。

输入格式:

输入在一行中首先给出一个正整数n,之后是n个整数,其间以空格分隔。

输出格式:

在一行中按照“min = 最小值”的格式输出n个整数中的最小值。

输入样例:

4 -2 -123 100 0

输出样例:

min = -123

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main() {
    int N, N1,  min, i;
    scanf("%d %d", &N, &N1);
    for(i=1, min = N1; i<N && scanf("%d", &N1)==1; i++)
        min=min>N1?N1:min;
    printf("min = %d", min);
    return 0;
}

7-3 求整数段和  分数 20

给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

输入格式:

输入在一行中给出2个整数A和B,其中−100≤A≤B≤100,其间以空格分隔。

输出格式:

首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X的格式输出全部数字的和X

输入样例:

-3 8

输出样例:

   -3   -2   -1    0    1
    2    3    4    5    6
    7    8
Sum = 30

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main(){
    int A, B, sum, i, j;
    scanf("%d %d", &A, &B);
    for(i=A, sum = 0, j = 1;i<=B;i++,j++){
        printf("%5d", i);
        sum += i;
        if(j%5==0)
            printf("\n");
    }
    if(j%6==0)
        printf("Sum = %d", sum);
    else
        printf("\nSum = %d", sum);
    return 0;
}

7-4 猜数字游戏  分数 20

猜数字游戏是令游戏机随机产生一个100以内的正整数,用户输入一个数对其进行猜测,需要你编写程序自动对其与随机产生的被猜数进行比较,并提示大了(“Too big”),还是小了(“Too small”),相等表示猜到了。如果猜到,则结束程序。程序还要求统计猜的次数,如果1次猜出该数,提示“Bingo!”;如果3次以内猜到该数,则提示“Lucky You!”;如果超过3次但是在N(>3)次以内(包括第N次)猜到该数,则提示“Good Guess!”;如果超过N次都没有猜到,则提示“Game Over”,并结束程序。如果在到达N次之前,用户输入了一个负数,也输出“Game Over”,并结束程序。

输入格式:

输入第一行中给出两个不超过100的正整数,分别是游戏机产生的随机数、以及猜测的最大次数N。最后每行给出一个用户的输入,直到出现负数为止。

输出格式:

在一行中输出每次猜测相应的结果,直到输出猜对的结果或“Game Over”则结束。

输入样例:

58 4
70
50
56
58
60
-2

输出样例:

Too big
Too small
Too small
Good Guess!

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main() {
    int M, N, n;
    int i;
    scanf("%d %d", &M, &N);
    for (i = 0; scanf("%d", &n) && n > 0 && n != M; i++) {
        if (i == N)
            break;
        if (n > M)
            printf("Too big\n");
        else if (n < M)
            printf("Too small\n");
    }
    if (n < 0)
        printf("Game Over");
    else {
        if (i == 0)
            printf("Bingo!\n");
        else if (i < 3)
            printf("Lucky You!\n");
        else if (i >= 3 && i < N)
            printf("Good Guess!\n");
        else
            printf("Game Over\n");
    }
    return 0;
}

7-5 高空坠球  分数 20

皮球从某给定高度自由落下,触地后反弹到原高度的一半,再落下,再反弹,……,如此反复。问皮球在第n次落地时,在空中一共经过多少距离?第n次反弹的高度是多少?

输入格式:

输入在一行中给出两个非负整数,分别是皮球的初始高度和n,均在长整型范围内。

输出格式:

在一行中顺序输出皮球第n次落地时在空中经过的距离、以及第n次反弹的高度,其间以一个空格分隔,保留一位小数。题目保证计算结果不超过双精度范围。

输入样例:

33 5

输出样例:

94.9 1.0

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main(){
    int n, i;
    double s, H;
    
    scanf("%lf %d", &H, &n);
    if(n==0)
        printf("0.0 0.0");
    else{
        for(i=0, s=0;i<n;i++){
            s+=H;
            H/=2;
            s+=H;
        }
        printf("%.1lf %.1lf", s-H, H);
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值