团体程序设计天梯赛-练习集 L1-003 个位数统计(c语言)

给定一个 k 位整数 N=dk−1​10k−1+⋯+d1​101+d0​ (0≤di​≤9, i=0,⋯,k−1, dk−1​>0),请编写程序统计每种不同的个位数字出现的次数。例如:给定 N=100311,则有 2 个 0,3 个 1,和 1 个 3。


输入格式:

每个输入包含 1 个测试用例,即一个不超过 1000 位正整数 N


输出格式:

对 N 中每一种不同的个位数字,以 D:M 的格式在一行中输出该位数字 D 及其在 N 中出现的次数 M要求按 D 的升序输出


输入样例:

100311

输出样例:

0:2
1:3
3:1

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB


 考察知识点:

1. 整型变量在储存单元中是以补码形式存储。分为两大类:有符号和无符号类型。

小类分为基本整形(int),短整型(short),长整型(long),双长型(long long)

注意:无符号类型大于等于0,在开头直接加unsigned,如 unsigned int,unsigned short。

相同小类在电脑的存储空间相同,如 int 和 unsigned int 都是4个字节,所以相同小类的无符号类型最大值取值大于有符号类型。因此unsigned long long 可取最大 2^62 -1,但是这里仍然小于1000位,因此不能用一个变量直接存储输入的整数

2. 条件语句

switch(表达式)

{

        case 常量1:语句1;

        case 常量2:语句2;

        ……

        default : 语句;

}

注意:表达式类型需要是整数类型(包括字符型),default不一定放最后,case后面的常量不能相同,一般情况下每个语句后面带break。


解题思路:

根据题目要求,正整数N的取值范围至1000位,这里用字符变量来存储数字。之后将数字取出,用switch计算出现次数,最后输出。


运行代码:

#include <stdio.h>
void fun(int s[],int n);
int main()
{
    char N[1000]={0};
    int n[10]={0};
    int i=0;
    while ((N[i]=getchar())!='\n')
    {
        switch (N[i])
        {
            case '0':n[0]++;break;
            case '1':n[1]++;break;
            case '2':n[2]++;break;
            case '3':n[3]++;break;
            case '4':n[4]++;break;
            case '5':n[5]++;break;
            case '6':n[6]++;break;
            case '7':n[7]++;break;
            case '8':n[8]++;break;
            case '9':n[9]++;break;
            default:putchar('\a');
        }
        i++;
        
    }
    for (i=0;i<10;i++)
    {
        if (n[i]!=0)
        {
            printf("%d:%d",i,n[i]);
            putchar('\n');//注意位置
        }
        
    }
    return 0;
}

### 关于 PTA 团体程序设计天梯赛 L1 练习题的解答与资源 PTA(Programming Teaching Assistant)是一个在线编程评测平台,广泛用于高校的教学和竞赛训练。对于团体程序设计天梯赛中的L1级别题目,通常涉及基础算法数据结构以及简单的逻辑推理[^1]。 以下是针对此类问题的一个通用解决方案框架: #### 输入处理 假设输入的第一行为列宽 \( N \) (\( N < 100 \)),第二行为待排版的字符串(长度不超过1000)。可以通过标准输入读取这些数据并存储到变量中[^2]。 ```python n = int(input()) # 列宽 text = input() # 待排版字符串 ``` #### 排版实现 为了完成古风排版功能,可以按照以下方式分割字符串并将结果按指定宽度打印出来。这里提供了一个基于Python的语言示例。 ```python def format_text(text, n): result = [] while len(text) > n: line = text[:n] text = text[n:] # 如果最后一字为空格,则删除该空格 if line[-1].isspace(): line = line.rstrip() text = ' ' + text result.append(line) if text: # 添加剩余部分 result.append(text) return result formatted_lines = format_text(text, n) for line in formatted_lines: print(line) ``` 此函数`format_text`接受两个参数:原始文本 `text` 和每行的最大字符数 `n` 。它会逐步截取字符串直到其长度小于等于给定列宽为止,并妥善处理边界情况如单词间多余空白等问题。 #### 输出展示 最终输出将是重新格式化后的多行文字串列表形式,其中每一项代表新的一行内容。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

z_e_r_o___

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值