PTA第5章 循环结构课后作业-3

7-1 统计字符  分数 20

本题要求编写程序,输入10个字符,统计其中英文字母、空格或回车、数字字符和其他字符的个数。

输入格式:

输入为10个字符。最后一个回车表示输入结束,不算在内。

输出格式:

在一行内按照

letter = 英文字母个数, blank = 空格或回车个数, digit = 数字字符个数, other = 其他字符个数

的格式输出。

输入样例:

aZ &
09 Az

输出样例:

letter = 4, blank = 3, digit = 2, other = 1

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
#include<ctype.h>
int main(){
    char ch;
    int i;
    int a=0, b=0, c=0, d=0;
    while((ch=getchar())!=EOF){
        if(isalpha(ch))
            ++a;
        else if(isspace(ch))
            ++b;
        else if(isdigit(ch))
            ++c;
        else
            ++d;
    }
    printf("letter = %d, blank = %d, digit = %d, other = %d", a, b-1, c, d);
    
    return 0;
}

7-2 逆序输出一个整数的各位数字  分数 20

本题要求编写程序,对输入的一个非负整数,从低位开始逐位分割并输出它的各位数字。

输入格式:

输入在一行中给出一个长整型范围内的非负整数。

输出格式:

从低位开始逐位输出该整数的各位数字,每个数字后面有一个空格。

输入样例:

1234560

输出样例:

0 6 5 4 3 2 1 

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main(){
    long N, n;
    scanf("%ld", &N);
    if(N==0)
        printf("0 ");
    while(N>0){
        n=N%10;
        N/=10;
        printf("%d ", n);
    }
    return 0;
}

7-3 统计学生成绩  分数 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

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
int main(){
    int N, a=0, b=0, c=0, d=0, e=0;
    scanf("%*d");
    while(scanf("%d", &N)!=EOF){
    if(N<60) e++;
    else if(N<70) d++;
    else if(N<80) c++;
    else if(N<90) b++;
    else a++;
    }
    printf("%d %d %d %d %d", a, b, c, d, e);
    
    return 0;
}

7-4 找完数  分数 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

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

//本段代码能够通过答案检测,但对于i=4不成立。
#include<stdio.h>
#include<stdbool.h>
int main() {
    int m, n;
    int i, j, sum;
    int a = 0;
    bool A = false, B = false;

    scanf("%d %d", &m, &n);
    for (i = m; i <= n; i++) {//i为被检测数

        for (j = 2, sum = 1; j <= i / 2; j++) {//j为每次判断因子
            if (i % j == 0) {
                A = true;
                sum += j;
            }
        }

        if (sum == i)//判断因子之和是否为被检测数
            B = true;

        if (A && B) {//A判断i是否为完数
            printf("%d = 1", i);//将1作为首项打出便于格式一致
            a++;

            for (j = 2; j <= i / 2; j++)
                if (i % j == 0)//打印每个因子
                    printf(" + %d", j);
            
            printf("\n");
            A = false, B = false;//更新,进行再次判断
        }
    }
    if (a == 0)
        printf("None");

    return 0;
}

7-5 小于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

感谢中国青年政治学院的同学修正数据!

代码长度限制

1000 KB

时间限制

400 ms

内存限制

64 MB

#include<stdio.h>
#include<stdbool.h>
int main() {
	int m, i, j, t;
	bool T = true;
	scanf("%d", &m);
	for (i = m, t = 0; i >= 2; i--, T = true) {
		if (t == 10)//共输出10素数
			break;

		for (j = 2; j * j <= i; j++) {
			if (i % j == 0)//判断i是否为素数
				T = false;
		}
		if (i == m)//除去自身为素数的情况
			continue;

		if (T) {
			printf("%6d", i);
			t++;
		}
	}

	return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值