第十三届蓝桥杯pythonB组试题A解题思路
时间: 2023-07-09 12:30:11 浏览: 122
第十三届蓝桥杯pythonB组试题A的解题思路如下:
题目描述:
给定一个整数n,输出它的各位数字之和。
解题思路:
此题可以通过取模运算和整除运算来实现。每次取n的个位数字,并将其累加到一个变量sum中,然后将n除以10,继续取下一个数字,直到n变为0为止。
代码实现如下:
```python
n = int(input()) # 输入整数n
sum = 0 # 定义变量sum
while n > 0:
sum += n % 10 # 取n的个位数字,并累加到sum中
n //= 10 # n整除10,去掉个位数字
print(sum) # 输出结果
```
注:如果输入的n是负数,则需要加上取绝对值的操作,因为负数的各位数字之和与其绝对值的各位数字之和是相同的。
相关问题
第十三届蓝桥杯pythonB组试题A:卡片 解题思路
第十三届蓝桥杯pythonB组试题A的解题思路如下:
题目描述:
有n张卡片,每张卡片上都写着一个正整数。定义一个整数x的权值为x在这n张卡片上出现的次数。请输出所有权值中的最大值。
解题思路:
此题可以用字典来实现,字典的键是卡片上的数字,值为该数字在卡片中出现的次数。遍历卡片时,可以用字典来统计每个数字的出现次数,最后再遍历一次字典,找到出现次数最多的数字及其出现次数。
代码实现如下:
```python
n = int(input()) # 输入卡片数量
cards = list(map(int, input().split())) # 输入卡片上的数字
d = {} # 定义字典
for c in cards:
if c not in d:
d[c] = 1
else:
d[c] += 1
max_cnt = 0 # 最大出现次数
for k, v in d.items():
if v > max_cnt:
max_cnt = v
print(max_cnt) # 输出结果
```
注:题目中没有说明卡片上的数字是不重复的,因此该程序也可以处理卡片上的数字有重复的情况。
阅读全文