打印一定范围内的水仙花数
题目内容:
水仙花数是指一个n位数 (n≥3),它的每个位上的数字的n次幂之和等于它本身。
例如:153是一个“水仙花数”,因为 153 是个 3位数,而1**3+5**3+3**3==153。
输入一个正整数max,输出100到max之间的所有水仙花数(包括max)。
输入格式:
共一行,为一个正整数。
输出格式:
若干行,从小到大输出水仙花数,一行为一个数。
输入样例:
2500
输出样例:
153
370
371
407
1634
时间限制:1000ms内存限制:32000kb
思路分析
1 将输入的数据的每个位上的数字分别存储(可以考虑将整数转换成字符串)
2 for循环遍历,循环可以直接从153(测试数据所知最小水仙花数)
3 将转换的字符串中的每个字符强制转换成整数型并进行n(字符串的长度)次幂求和
代码实现
num = int(input())
for i in range(153,num+1): //遍历153~num范围内的所有整数
st = str(i) //转换成字符串
n = len(st) //i的位数
sum = 0
for j in range(n):
sum += (int(st[j]))**n //每个位上的数字的n次幂之和
if(i == sum): //判断是否是水仙花数
print(i)
输入两个字符串,输出两个字符串集合的并集
题目内容:
输入两个字符串,输出两个字符串集合的并集。
为保证输出结果一致,请将集合内元素排序之后再输出,
如对于集合aset,可输出sorted(aset)。
输入格式:
共两行,每一行为一个字符串
输出格式:
共一行,为一个集合
输入样例:
abc
bcd
输出样例:
['a', 'b', 'c', 'd']
时间限制:500ms内存限制:32000kb