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