任意进制间转换

Posted 萌新上路

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了任意进制间转换相关的知识,希望对你有一定的参考价值。

整体思路:先把进制转化为十进制,在将十进制树转化为所需进制/

 

优化:二进制 八进制 十六进制间可以直接转化

 

/*
问题:任意进制间的转换(用c语言实现)
编程将任意d1进制的正整数转换成d2进制表示形式。 其中(2≤d1≤16,2≤d2≤16) 当进制大于10时,在每一位上的A、B、C、D、E、F分别代表数值10、11、12、13、14、15。

输入:用空格分开的三个数,分别表示进制d1下要转换的数num、进制d1、进制d2;

输出:数X的d2进制表示形式。

输入示例:
101111   2  16

1030    2  10

aaaa  16  2

hhjssk  10  8

输出示例:
2F

error

100101010100000

error
*/

#include<stdio.h>

#define M sizeof(unsigned int)*8

unsigned long n;

int trans1(char a[],int d1)   /*将d1进制的num,转换为十进制数s*/
{

    int i=0,num,s=0,P=1;

    while(P)
    {
        if(a[i]>=A&&a[i]<=F)   num=a[i]-0-7;
        else if (a[i]>=a&&a[i]<=f) num=a[i]-0-39;
        else if (a[i]>=0&&a[i]<=9) num=a[i]-0;
        else{
               printf("Error!\n");
               break;
            }
        if(num<d1)
        {
            if(i==0) s=num;
            else
            {
                s*=d1;
                s+=num*d1;
             }
         }
        else
        {
            printf("Error!\n");       /*不合规则(d1进制)的num*/
            break;
         }

        if( a[++i]==\0) P=0;

      }
      return s;
}


int trans2(unsigned long n, int d, char s[]) /* 将无符号整数n翻译成d(2<=d<=16)进制表示的字符串s */
{
    static char digits[] ="0123456789ABCDEF";  /* 十六进制数字的字符 */
    char buf[M+1];
    int j, i = M;
    s[0]=\0;
    if(d<2||d>16)
    {
        s[0]=\0;  /* 不合理的进制,置s为空字符串 */
        return 0;   /* 不合理的进制,函数返回0 */
    }
    buf[i]=\0;
    do
    {
        buf[--i]=digits[n%d]; /*译出最低位,对应字符存入对应工作数组中*/
        n/=d;
    }while(n);

    for(j=0;(s[j]=buf[i])!=\0;j++,i++); /*将译出在工作数组中的字符串复制到s */

    return j;
}


main()
{

    char str[33];
    int d1,d2;
    while(scanf("%s %d %d",&str,&d1,&d2)!=EOF)
    {
        n=trans1(str,d1);
        if(n&&trans2(n,d2,str)) printf("%s\n",str);
        str[0]=\0;
     }
}

 

以上是关于任意进制间转换的主要内容,如果未能解决你的问题,请参考以下文章

java 的任意进制间转换(很方便)

2~16进制间任意进制转换器

进制间的相互转换

计算机组成原理——进制间相互转换

计算机组成原理——进制间相互转换

Java进制间的转换