我有一段考卷上的代码,我正在做额外的帮助。在
我需要帮助的代码:
def Denary(Hex):
Result = ''
ErrorFound = False
DenaryEquivalent = ''
EmptyInput=""
for ThisHexDigit in Hex:
if ThisHexDigit in ['1','2','3','4','5','6','7','8','9','0','A','B','C','D','E','F']:
if ThisHexDigit == '0': DenaryEquivalent = '0'
elif ThisHexDigit == '1': DenaryEquivalent = '1'
elif ThisHexDigit == '2': DenaryEquivalent = '2'
elif ThisHexDigit == '3': DenaryEquivalent = '3'
elif ThisHexDigit == '4': DenaryEquivalent = '4'
elif ThisHexDigit == '5': DenaryEquivalent = '5'
elif ThisHexDigit == '6': DenaryEquivalent = '6'
elif ThisHexDigit == '7': DenaryEquivalent = '7'
elif ThisHexDigit == '8': DenaryEquivalent = '8'
elif ThisHexDigit == '9': DenaryEquivalent = '9'
elif ThisHexDigit == 'A': DenaryEquivalent = '10'
elif ThisHexDigit == 'B': DenaryEquivalent = '11'
elif ThisHexDigit == 'C': DenaryEquivalent = '12'
elif ThisHexDigit == 'D': DenaryEquivalent = '13'
elif ThisHexDigit == 'E': DenaryEquivalent = '14'
elif ThisHexDigit == 'F': DenaryEquivalent = '15'
elif ThisHexDigit == '10': DenaryEquivalent = '16'
elif Hex==EmptyInput:
print('Empty input, try again.')
Result = Result + DenaryEquivalent
else:
ErrorFound == True
print('You have made a mistake')
def HexToDenary():
Hexadecimal = input('Enter a hexadecimal number: ')
Converted = Denary(Hexadecimal)
print (Converted)
运行时,没有错误,程序正常工作(这只是其中的一部分)。我想知道的是如何将结果相加,而不是以二进制形式出现。例如,如果我输入'BB',我得到的是'1111',而不是187。这应该很容易,但我想不通。在
我知道这是一段过于复杂的代码,但这是我们给出的。在
你的程序使用字符串。
+
连接字符串。在你需要把你的操作数转换成数字。在
此外,您应该使用
dict
从一组数据映射到另一组数据:还请注意,您的程序不能正确执行转换,因为它不能将每个数字提升到正确的幂。在
您需要在程序中更改2行
到
^{pr2}$以及
^{3}$到
当然你可以用字典来简化它
问题是你的等价物是字符串,而不是整数,所以它们被连接起来,而不是相加。在
所以要解决:
然而,你表现出了一种非常糟糕的方式。当然,最好的方法是使用Python内置的处理不同的基数(
^{pr2}$int(hex_string ,16)
),但是,假设这是一个编程练习,而不是使用大量if语句,使用dict
将是合适的。在快速制作方法如下:
^{3}$Enumerate返回
(n, v)
的元组,其中v是传入的iterable(在本例中为字符串)中的每个值,n是从0开始计数的数字。我们使用dict理解来理解这个,颠倒键和值,并制作字典。如果你觉得这更容易或更清楚的话,你可以用手把它写出来。在然后我们就可以:
这个循环遍历我们的十六进制字符串,将前面的值乘以16(在我们继续下去的过程中,每个数字的值比左边的数字小16倍),然后再加上新数字的值。在
还值得注意的是,PEP-8建议将
CapWords
用于类,lowercase_with_underscores
用于局部变量。在我以前的回答是这样的:
我们先反转字符串以获得最小值的数字,然后枚举它们来告诉我们数字的位置(因此也是值)。我们取16的幂次方(在那个位置得到
1
)的值,然后乘以这个数字的值,然后把它们加在一起。在这是可行的,但有人指出这是一种效率较低的方法。在
相关问题 更多 >
编程相关推荐