问题描述
给定n个十六进制正整数,输出它们对应的八进制数。
样例输入
2
39
123ABC
样例输出
71
4435274
n = int(input()) #输入一个正整数n,表示n个十六进制正整数
for i in range(0,n):
ans = format(int(input(), 16), 'o') #16进制转8进制
n = n-1
print(ans)
十六进制转十进制
样例输入
FFFF
样例输出
65535
ans = int(input(), 16)
print(ans)
十进制转十六进制
样例输入
30
样例输出
1E
print(format(int(input()),'X'))
拓展:python十进制转换为任意进制
一、使用栈
from pythonds.basic import Stack
def baseConverter(decNumber,base):
digits = "0123456789ABCDEF"
remstack = Stack()
while decNumber > 0:
rem = decNumber % base
remstack.push(rem)
decNumber = decNumber // base
newString = ""
while not remstack.isEmpty():
newString = newString + digits[remstack.pop()]
return newString
#实例
decNumber,base=map(lambda x:int(x),input('请输入10进制数字与转换进制:').split())
newString=baseConverter(decNumber,base)
print(newString)
二、使用递归
'''将整数转换成2~16为进制基数的字符串'''
def toStr(n,base):
convertString = "0123456789ABCDEF"
if n < base:
return convertString[n]
else:
return toStr(n//base,base)+convertString[n%base]
n,base = map(int,input().split()) #输入整数与进制基数
num=toStr(n,base)
print(num)
第六行首先进行递归调用,然后才拼接余数对应的字符串,因此程序能够正确工作。如果将convertString查找和返回toStr调用反转,结果字符串就是反转的。