PAT乙级练习题_1021“个位数统计”_python解题

本博客介绍了一个简单的程序设计问题,如何统计一个大整数中不同个位数字出现的次数。通过输入一个不超过1000位的正整数,程序将输出每种个位数字及其出现的次数,按数字升序排列。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原题

给定一个 k 位整数 N = d k − 1 1 0 k − 1 d_{k−1}10^{k−1} dk110k1 + ⋯ + d 1 1 0 1 d_110^1 d1101 + d 0 d_0 d0 ( 0 ≤ d i d_i di ≤ 9, i = 0, ⋯, k−1, d k − 1 d_{k−1} dk1 > 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

my answer

这道题是一个非常简单的题,直接看代码就能看懂

number = eval(input())

list = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
tmp = 10
while number!=0:
    tmp = number % 10
    number //= 10
    list[tmp] += 1

for i in range(len(list)):
    if list[i] != 0:
        print("{}:{}".format(i, list[i]))
### 关于PAT乙级Python 1015题目 针对PAT乙级中的Python 1015题目,虽然直接关于此题目的具体解析未在提供的参考资料中明确提及[^2],但是可以基于PAT乙级的一般解题模式以及编程竞赛的特点来构建解答框架。 #### 题目概述 通常情况下,PAT乙级的题目会围绕基础算法、字符串处理、简单数学运算等方面展开。对于编号为1015的具体题目,在缺乏确切描述的情况下,假设该题目属于常见的编程挑战之一,比如涉及数组操作、字符串转换或是简单的逻辑判断等。 #### 解题思路 考虑到PAT系列试题的设计原则,解决这类问题的关键在于理解题目要求并选择合适的数据结构和算法: - **仔细阅读题目说明**:确保完全明白输入输出的要求。 - **设计合理的解决方案**:依据题目特性决定采用何种方法最有效率地解决问题。 - **编写简洁高效的代码**:利用Python的优势简化语法表达,提高程序可读性和执行效率。 - **测试与调试**:通过多个样例验证自己的答案是否正确无误。 #### 代码实现 下面提供一段通用性的Python代码模板作为参考,适用于大多数PAT类型的编程任务(请注意实际比赛中应严格按照官方给定的任务细节调整参数设置): ```python def solve_problem(input_data): result = [] # 存储最终的结果列表 for item in input_data: processed_item = process(item) # 对单个元素进行必要的预处理 computed_value = compute(processed_item) # 执行核心计算逻辑 result.append(computed_value) return format_output(result) if __name__ == "__main__": inputs = read_input() # 获取用户输入或其他形式的数据源 output = solve_problem(inputs) print(output) # 或者按照特定格式写出到文件/标准输出流 ``` 这段伪代码展示了如何接收外部数据、逐项处理并将结果整理成期望的形式返回或打印出来。具体的`process()`、`compute()`函数定义需根据实际情况定制化开发;而`read_input()`则负责获取初始条件或案例集。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值