python任意进制转换_python 十进制转换成任意进制

记得大学时代,参加学校举行的编程大赛,其中有道题是:

编写一函数,实现十进制转换成十六进制。

看起来非常简单的一道题,最后竟然没有实现,想想都觉得惭愧啊,回去网上一搜,那是相当的easy的事情;时隔五六年了,工作中一直是用java,最近学习python,所以突然想到这个问题,就用python来实现这道题。下面使用两种方法分别实现:

一、循环

defdecimalToNBaseByNormal(decimalVar, base):

tempList=[]

temp=decimalVar

i=0while (temp >0):

ord= temp %baseif (ord > 9): #如果余数大于9,则以字母的形式表示

ord = chr(65 + (ord - 10)) #把数字转换成字符

tempList.append(ord)

temp= int(temp /base)

i= i + 1tempList.reverse();#print(tempList)

binary = ""

for j inrange(len(tempList)):

binary= binary +str(tempList[j]);print("the decimal is: %d and after convering by %d base is %s"%(decimalVar, base, binary))

里面要注意的一点就是,当余数大于9时,要转换成字符表示;用循环的方法实现,思路非常清晰,至于转换算法这里就不多介绍,可以看参考[1];在该实现过程中碰到的问题是,怎么把数字转换成字符;当然首先是ascii对应表,转换方法如下:

ord = chr(65 + (ord - 10))

其中,ord为余数,转换后就对应ascii从A开始的字符,python 3.3中可以使用chr函数直接转换成字符

二、递归

defdecToNBaseByRecursion(dec, base):if (dec ==0):returndecToNBaseByRecursion(int(dec/base), base)

ord= dec %baseif (ord > 9):

ord= chr(65 + (ord - 10))

sys.stdout.write(str(ord))

递归方法,实现使得代码非常简洁,但理解起来不是那么简单;递归实现过程中,碰到一个输出问题,python 3.3中,函数print默认自动换行,网上后面加逗号的方法,试了无效,所以直接使用stdout输出,这就要在使用import sys。

主代码:

importsysdefmain():

decimal= eval(input("please input the decimal for converting binary:"))

base= eval(input("please input base:"))

decimalToNBaseByNormal(decimal, base)

decToNBaseByRecursion(decimal, base)

python版本 3.3

上面的链接是code.google,不翻是上不去的,我朝”伟大的杰作“啊!

python刚入门,只考虑运行结果,没有考虑任何性能问题,有不正的地方,请指正!

当然python里面有更简单的函数直接输出:

二进制 bin()

八进制 oct()

十六进制 hex()

未完待续:任意进制转换成十进制

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值