目录
7-2 编写程序,求自然数1至n(n>1)的累加和。 (10 分)
7-1 电子汪 (10 分)
据说汪星人的智商能达到人类 4 岁儿童的水平,更有些聪明汪会做加法计算。比如你在地上放两堆小球,分别有 1 只球和 2 只球,聪明汪就会用“汪!汪!汪!”表示 1 加 2 的结果是 3。
本题要求你为电子宠物汪做一个模拟程序,根据电子眼识别出的两堆小球的个数,计算出和,并且用汪星人的叫声给出答案。
输入格式:
输入在一行中给出两个 [1, 9] 区间内的正整数 A 和 B,用空格分隔。
输出格式:
在一行中输出 A + B 个
Wang!
。
输入样例:
2 1
输出样例:
Wang!Wang!Wang!
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int a,b,c,i;
scanf("%d %d",&a,&b);
c=a+b;
for(i=1;i<=c;i++){
printf("Wang!");
}
return 0;
}
7-2 编写程序,求自然数1至n(n>1)的累加和。 (10 分)
编写程序,求自然数1至n(n>1)的累加和。其中n的值从键盘输入。
输入格式:
输入一个自然数赋给变量n。
输出格式:
输出自然数1至n的累加和。
输入样例:
10
输出样例:
55
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int a,c,i;
c=0;
scanf("%d",&a);
for(i=1;i<=a;i++){
c=c+i;
}
printf("%d",c);
return 0;
}
7-3 乐乐的得分(2010南海小学甲组) (20 分)
“六一”儿童节到了,乐乐参加了学校组织的诗歌朗颂比赛,这个比赛有n个评委,各参赛者朗颂完后,每个评委会马上打出一个分数,而参赛者的得分是指这n个分数里去掉一个最高分和一个最低分后的(n-2)个数的平均分。现在乐乐想知道自己的得分是多少。
输入格式:
第一行是一个整数n(3≤n≤20000)。
第二行是n个100以内的正整数,每个整数之间用一个空格隔开。
输出格式:
输出文件只有一个数,表示乐乐的分数,得数保留小数点后一位数字。
输入样例:
10
95 90 88 92 94 98 98 93 93 91
输出样例:
93.3
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int n,g,i;
double s=0.0,a=0.0;
scanf("%d",&n);
for(i=1;i<=n;i++){
scanf("%d",&g);
s=s+g;
}
a=s/n;
printf("%.1f\n",a);
return 0;
}
7-4 打印九九口诀表 (20 分)
下面是一个完整的下三角九九口诀表:
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
1*4=4 2*4=8 3*4=12 4*4=16
1*5=5 2*5=10 3*5=15 4*5=20 5*5=25
1*6=6 2*6=12 3*6=18 4*6=24 5*6=30 6*6=36
1*7=7 2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49
1*8=8 2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64
1*9=9 2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81
本题要求对任意给定的一位正整数N
,输出从1*1
到N*N
的部分口诀表。
输入格式:
输入在一行中给出一个正整数
N
(1≤N
≤9)。
输出格式:
输出下三角
N*N
部分口诀表,其中等号右边数字占4位、左对齐。
输入样例:
4
输出样例:
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
1*4=4 2*4=8 3*4=12 4*4=16
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int i,j,N;
scanf("%d",&N);
for(i=1;i<=N;i++){
for(j=1;j<=i;j++){
printf("%d*%d=%-4d",j,i,j*i);
}
printf("\n");
}
return 0;
}
7-5 计算阶乘和 (20 分)
对于给定的正整数N,需要你计算 S=1!+2!+3!+...+N!。
输入格式:
输入在一行中给出一个不超过10的正整数N。
输出格式:
在一行中输出S的值。
输入样例:
3
输出样例:
9
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int i,j,n,s,f;
scanf("%d",&n);
for(i=1;i<=n;i++){
f=1;
for(j=1;j<=i;j++){
f=f*j;
}
s+=f;
}
printf("%d",s);
return 0;
}
7-6 统计两整数间被3整除数的个数 (20 分)
输入两个整数,n1,n2(要求n1<n2),统计两整数范围内被3整除的数的个数。
输入格式:
在一行输入2个整数。两个整数之间用一个空格间隔
输出格式:
按照“a=n1,b=n2,n=个数”的顺序输出。其中n1、 n2和个数的输出格式均为原样输出,不加宽度控制。
输入样例:
10 15
输出样例:
a=10,b=15,n=2
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int n1,n2,i;
int j=0;
scanf("%d %d",&n1,&n2);
for(i=n1;i<=n2;i++){
if(i%3==0){
j=j+1;
}
else j=j+0;
}
printf("a=%d,b=%d,n=%d",n1,n2,j);
return 0;
}
7-7 求奇数分之一序列前N项和 (20 分)
本题要求编写程序,计算序列 1 + 1/3 + 1/5 + ... 的前N项之和。
输入格式:
输入在一行中给出一个正整数N。
输出格式:
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。
输入样例:
23
输出样例:
sum = 2.549541
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int N,i;
scanf("%d",&N);
double a;
double sum=0.0;
for(i=1;i<=2*N-1;i+=2){
sum+=(1.000000/i);
}
printf("sum = %0.6lf",sum);
return 0;
}
7-8 找出最小值 (20 分)
本题要求编写程序,找出给定一系列整数中的最小值。
输入格式:
输入在一行中首先给出一个正整数n,之后是n个整数,其间以空格分隔。
输出格式:
在一行中按照“min = 最小值”的格式输出n个整数中的最小值。
输入样例:
4 -2 -123 100 0
输出样例:
min = -123
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int n;
scanf("%d",&n);
int a[n];
int i,min;
for(i=0;i<n;i++){
scanf("%d",&a[i]);
if(i==0){
min=a[0];
}
if(a[i]<min){
min=a[i];
}
}
printf("min = %d",min);
return 0;
}
7-9 求整数段和 (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
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int a,b,i,n,sum;
sum=0;
scanf("%d %d",&a,&b);
for (i=a,n=0;i<=b;i++){
if (n!=0&&n%5==0){
printf("\n");
printf("%5d",i);
}
else{
printf("%5d",i);
}
n++;
}
for(i=a;i<=b;i++){
sum=sum+i;
}
printf("\nSum = %d",sum);
return 0;
}
7-10 猜数字游戏 (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!
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int key,n,guess,i;
i=1;
scanf("%d %d",&key,&n);
scanf("%d",&guess);
if(i<=n&&guess>=0&&guess!=key)
do{i++;
if(guess>key)printf("Too big\n");
if(guess<key)printf("Too small\n");
scanf("%d",&guess);
} while(guess!=key);
if(i<=n&&guess==key){
if(i==1)printf("Bingo!");
if(i<=3&&i>1)printf("Lucky You!");
if(i>3&&i<=n)printf("Good Guess!");
}
if(i>n)printf("Game Over");
if(guess<0)printf("Game Over");
return 0;
}
7-11 高空坠球 (20 分)
皮球从某给定高度自由落下,触地后反弹到原高度的一半,再落下,再反弹,……,如此反复。问皮球在第n次落地时,在空中一共经过多少距离?第n次反弹的高度是多少?
输入格式:
输入在一行中给出两个非负整数,分别是皮球的初始高度和n,均在长整型范围内。
输出格式:
在一行中顺序输出皮球第n次落地时在空中经过的距离、以及第n次反弹的高度,其间以一个空格分隔,保留一位小数。题目保证计算结果不超过双精度范围。
输入样例:
33 5
输出样例:
94.9 1.0
#include <stdio.h>
#include <math.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
long int h,n,i;
double d,k;
k=0.0;
scanf("%ld %ld",&h,&n);
d=h;
if(n==0){
printf("0.0 0.0");
}
else{
for(i=2;i<=n;i++){
k=pow(0.5,i-1)*h;
d=d+k*2.0;
}
printf("%.1lf %.1lf",d,pow(0.5,n)*h);
}
return 0;
}
7-12 统计字符 (20 分)
本题要求编写程序,输入10个字符,统计其中英文字母、空格或回车、数字字符和其他字符的个数。
输入格式:
输入为10个字符。最后一个回车表示输入结束,不算在内。
输出格式:
在一行内按照
letter = 英文字母个数, blank = 空格或回车个数, digit = 数字字符个数, other = 其他字符个数
的格式输出。
输入样例:
aZ &
09 Az
输出样例:
letter = 4, blank = 3, digit = 2, other = 1
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int i;
int letter=0,blank=0,digit=0,other=0;
char ch;
for(i=1;i<=10;i++){
ch=getchar();
if(ch>='0'&&ch<='9')digit++;
else if((ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z'))letter++;
else if(ch==' '||ch=='\n')blank++;
else{
other++;
}
}
printf("letter = %d, blank = %d, digit = %d, other = %d",letter,blank,digit,other);
return 0;
}
7-13 逆序输出一个整数的各位数字 (20 分)
本题要求编写程序,对输入的一个非负整数,从低位开始逐位分割并输出它的各位数字。
输入格式:
输入在一行中给出一个长整型范围内的非负整数。
输出格式:
从低位开始逐位输出该整数的各位数字,每个数字后面有一个空格。
输入样例:
1234560
输出样例:
0 6 5 4 3 2 1
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
long int n;
int a;
scanf("%ld",&n);
while(n>=10){
a=n%10;
n=n/10;
printf("%d ",a);
}
if(n<10){
printf("%d ",n);
}
return 0;
}
7-14 统计学生成绩 (20 分)
本题要求编写程序读入N个学生的百分制成绩,统计五分制成绩的分布。百分制成绩到五分制成绩的转换规则:
- 大于等于90分为A;
- 小于90且大于等于80为B;
- 小于80且大于等于70为C;
- 小于70且大于等于60为D;
- 小于60为E。
输入格式:
输入在第一行中给出一个正整数N(≤1000),即学生人数;第二行中给出N个学生的百分制成绩,其间以空格分隔。
输出格式:
在一行中输出A、B、C、D、E对应的五分制成绩的人数分布,数字间以空格分隔,行末不得有多余空格。
输入样例:
7
77 54 92 73 60 65 69
输出样例:
1 0 2 3 1
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int n;
scanf("%d",&n);
int a[n];
int ninty=0,eighty=0,seventy=0,sixty=0,fail=0;
int i;
for(i=0;i<n;i++){
scanf("%d",&a[i]);
if(a[i]>=90)ninty=ninty+1;
else if(a[i]>=80&&a[i]<90)eighty=eighty+1;
else if(a[i]>=70&&a[i]<80)seventy=seventy+1;
else if(a[i]>=60&&a[i]<70)sixty=sixty+1;
else if(a[i]<60)fail=fail+1;
}
printf("%d %d %d %d %d",ninty,eighty,seventy,sixty,fail);
return 0;
}
7-15 找完数 (20 分)
所谓完数就是该数恰好等于除自身外的因子之和。例如:6=1+2+3,其中1、2、3为6的因子。本题要求编写程序,找出任意两正整数m和n之间的所有完数。
输入格式:
输入在一行中给出2个正整数m和n(1<m≤n≤10000),中间以空格分隔。
输出格式:
逐行输出给定范围内每个完数的因子累加形式的分解式,每个完数占一行,格式为“完数 = 因子1 + 因子2 + ... + 因子k”,其中完数和因子均按递增顺序给出。若区间内没有完数,则输出“None”。
输入样例:
2 30
输出样例:
6 = 1 + 2 + 3
28 = 1 + 2 + 4 + 7 + 14
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int m,n,i,j,sum,k,p;
sum=0;
p=1;
scanf("%d %d",&m,&n);
for(i=m;i<=n;i++){
sum=0;
for(j=1;j<i;j++){
if (i%j==0)sum=sum+j;
}
if (sum==i){
p=0;
printf("%d = 1",i);
for(k=2;k<i;k++){
if(i%k==0)printf(" + %d",k);
}
printf("\n");
}
}
if (p==1)printf("None\n");
return 0;
}
7-16小于m的最大的10个素数 (20 分)
给定一个整数m(50<m<20000),找出小于m的最大的10个素数。
输入格式:
输入在一行中给出一个正整数m(50<m<20000)。
输出格式:
在一行中按递减顺序输出10个满足条件的素数,每个素数输出占6列。没有其它任何附加格式和字符。
输入样例:
229
输出样例:
227 223 211 199 197 193 191 181 179 173
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main(){
int n,i,m,k;
i=1;
scanf("%d",&n);
for(m=n-1;m>1;m--){
for(k=2;k<=sqrt(n);k++){
if(m%k==0){
break;
}
}
if(k>sqrt(m)&&i<=10){
printf("%6d",m);
i++;
}
}
return 0;
}