思路:除以n得商取模,然后再用商除以n得商取模,依此类推,直到商为0,最后将余数逆序输出即为结果
核心代码
result = "" # 结果
while x > 0:a = x % n # 余数result = result + str(a)x = x // n # 商print(result[::-1]) # 逆序输出
数字大于十可能要用编码来表达,例如十进制转换十六进制,当数字大于等于10时,10用A表示,11用B表示…
x = int(input)
n = 16
s = ""
while x > 0:result = x % nif result >= 10: result = chr(65+(result-10)) #chr函数返回对应ASCII码的字符,字符A的ASCII码为65s = s + str(result)x = x // nprint(s[::-1])
例题
用字母A对应数字1,B对应2,以此类推,用Z对应26。对于27以上的数字,用两位或更长位的字符串来对应,例如AA 对应27,AB对应28,AZ对应52,LQ 对应329。请问输入一个任意数,求其对应的字符串
虽然这题说大于27才进位,但是开始是从1开始的,也就是说数字范围是1到26,所以还是26进制,还要注意的是由于模26结果范围是0到25,所以当结果为0时要单独判断为字符Z
x = int(input())
n = 26
result = ""
while x > 0:a = x % nif a == 0:a = 'Z'else:a = (chr(a + 65 - 1))result = result + ax = x // nprint(result[::-1])