python 十进制转换成任意进制

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

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

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

一、循环

def decimalToNBaseByNormal(decimalVar, base):
    tempList = []
    temp = decimalVar
    i = 0
    while (temp > 0):
        ord = temp % base
        if (ord > 9): #如果余数大于9,则以字母的形式表示
            ord = chr(65 + (ord - 10))   #把数字转换成字符
        tempList.append(ord)
        temp = int(temp / base)
        i = i + 1
    tempList.reverse();
    #print(tempList)
    binary = ""
    for j in range(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函数直接转换成字符

二、递归

def decToNBaseByRecursion(dec, base):
    if (dec == 0):
        return
    decToNBaseByRecursion(int(dec/base), base)
    ord = dec % base
    if (ord > 9):
        ord = chr(65 + (ord - 10))
    sys.stdout.write(str(ord))

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

主代码:

import sys
def main():
    decimal = eval(input("please input the decimal for converting binary: "))
    base = eval(input("please input base: "))
    decimalToNBaseByNormal(decimal, base)
    decToNBaseByRecursion(decimal, base)

工具:PyScripter

python版本 3.3

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

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

完整代码

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

二进制  bin()

八进制  oct()

十六进制  hex()

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

时间: 2024-10-15 17:25:05

python 十进制转换成任意进制的相关文章

NOJ 1012 进制转换(十进制转换成任意进制)

题目: 进制转换 时间限制(普通/Java) : 1000 MS/ 3000 MS          运行内存限制 : 65536 KByte总提交 : 1819            测试通过 : 525  题目描述 将一个十进制数N转换成R进制数输出,2≤R≤16,R≠10. 输入 多行.第一行指出以下一共有多少组数据,后续每行包含两个整数N和R,以空格分隔,-100000≤N≤100000,2≤R≤16,R≠10. 输出 多行.每行给出转换后的R进制数. 样例输入 37 223 12-4 

十进制转换成其它进制的通用写法(查表法)

 //十进制转换成其它进制的通用写法(查表法)  class Transform  { public static void main(String[] args) {    toHex3(60);    System.out.println();    toOctal2(20);    System.out.println();    toBinary2(6); }  public static void toAny(int num,int base,int offSet)  {   char

java基础:十进制转换到任意进制

十进制转换到其他进制: 除基取余,直到商为0,余数反转.

进制的转换 以及十进制转换成x进制的代码

由 2进制的思路,满2进1    那么x进制就是满x进1: 对于非二进制数   1221;  如果他是3进制数 那么他的   十进制表示的数字就为,3^0*1+3^1*2+3^2*2+3^3*1 = 1+6+18+27 = 52; #include<iostream> using namespace std; #define MAXSIZE 100typedef int ElemType; typedef struct { //顺序栈的数据类型 ElemType *base; ElemType

python 十进制整数转换为任意进制(36以内)

def baseN(num, b): return ((num == 0) and "0") or (baseN(num // b, b).lstrip("0") + "0123456789abcdefghijklmnopqrstuvwxyz"[num % b])

十进制转换成二进制以 二进制转换成 8进制和16进制

十进制转换成二进制 举例:752(十进制数) --> 转换成 二进制数 从下往上 读取数据 二进制数为 : 011110000 2.二进制转换成8进制 (开头用 0 表示) 111 -> 表示的十位数 为 7,也是 8进制 每位上 最大的数字 011110000 转换为  8进制 ,从右到左  ,三位 隔开      011-110-000 , 3.二进制转换成16进制(开头用0x表示) 与 二进制转换 大体相同,区别在于 , 在二进制数中,每四位数隔开 ,再分别计算 得到十进制 ,再 进行

将16进制字符串转换成16进制数据

var tb1 = Tb1.Text; if (string.IsNullOrEmpty(tb1)) { tb1 = "0000"; } var s1 = tb1.Substring(0, 2); var int_1 = Convert.ToInt32(s1, 16); var s2 = tb1.Substring(2, 2); var int_2 = Convert.ToInt32(s2, 16); var bt1 = Convert.ToByte(int_1); var bt2 =

ip地址转换成16进制long

<span style="font-size:18px;">public class IpUtil { /** * ip地址转换成16进制long * @param ipString * @return */ public static Long ipToLong(String ipString) { Long[] ip = new Long[4]; int pos1= ipString.indexOf("."); int pos2= ipString.

10进制转换成8进制

package cast; import java.util.Collections;import java.util.LinkedList;import java.util.List; public class Cast {    //测试    public static void main(String[] args) {        int a = Cast.castNum(100);        System.out.println(a);            }