解题思路:
注意事项:
参考代码:
n=int(input())
m=int(input())
#创建二维数组
#数据最多取到1000000,所以位数之和最大为9+9+9+9+9+9=54
arr=[[0 for i in range(1)] for j in range(55)]
for i in range(1,n+1):
#i的位数之和sum
sum=0
num=i
num_str=str(num)
length=len(num_str)
for j in range(length):
sum=sum+num%10
num=num//10
#在二维数组索引sum位置添加数据i
arr[sum].append(i)
#二维数组转换成一维数组
a=[element for row in arr for element in row ]
#删除数据为0的数
i=0
while i<len(a):
if a[i]==0:
del a[i]
else:
i+=1
print(a[m-1])
0.0分
3 人评分
数字整除 (C语言代码)浏览:767 |
求最大公约数-模板题浏览:874 |
C语言程序设计教程(第三版)课后习题7.5 (C++代码)浏览:782 |
C语言训练-阶乘和数* (C语言代码)浏览:981 |
校门外的树 (C语言代码)浏览:714 |
破解简单密码 (C语言代码)浏览:1761 |
C二级辅导-同因查找 (C语言代码)浏览:660 |
Biggest Number (C++代码)回溯法浏览:1612 |
C语言考试练习题_一元二次方程 (C语言代码)浏览:734 |
蓝桥杯历届试题-九宫重排 (C++代码)浏览:2783 |