ACM内部函数--数学问题--任意进制转换

本文探讨了两种进行任意进制转换的方法,包括通过十进制中介的模拟转换过程以及直接的进制转换策略,适用于ACM竞赛中的数学问题解决。
摘要由CSDN通过智能技术生成

    第一种方法思想:就是模拟进制转换的过程,用十进制作为转换的中介。


#include <iostream>
#include <string>
#include <cmath>
using namespace std;

/*将一个整型数字转化成字符型数字,例如 8->'8',12->'c'*/
char numToChar(char num){
    /*num是0到9之间的数字*/
    if(num<=9&&num>=0){
        num+=48;
    }

    /*num是10到15之间的数字*/
    else{
        switch(num){
            case 10:num='A';
            case 11:num='B';
            case 12:num='C';
            case 13:num='D';
            case 14:num='E';
            case 15:num='F';
        }
    }
    return num;
}

/*将一个字符型数字转化成整型数字,例如 '8'->8,'c'->12*/
int charToNum(char &num){
    /*num是0到9之间的字符型数字*/
    if(num<='9'&&num>='0'){
        num-=48;
    }

    /*num是'A'到'F'之间的字符型数字*/
    else{
        switch(num)
        {
        case 'A':
        case 'a':
            num=10;
        case 'B':
        case 'b':
            num=11;
        case 'C':
        case 'c':
            num=12;
        case 'D':
        case 'd':
            num=13;
        case 'E':
        case 'e':
            num=14;
        case 'F':
        case 'f':
            num=15;
        }
    }
    return num;
}

/*将任意进制整数转化为十进制整数,返回转化
后的十进制整数,num为任意进制整数,binary为
该整数的进制*/
int anyBinaryToDecimal(string num,int binary){
    int len=num.size();
    int decimal_num=0;
    for(int i=0;i<len;i++){
        decimal_num+=charToNum(num[i])*pow(binary,len-i-1);
    }
    return decimal_num;
}

/*将十进制转化为任意进制,
decimal为十进制整数,binary为需要
转化的进制*/
void decimalToAnyBinary(int decimal,int binary){
    string result;//保存x进制数
    char temp;
    while(decimal>0){
        temp=decimal%binary;
        result+=numToChar(temp);//将字符串拼接起来
        decimal=decimal/binary;
    }

    /*输出转化后的x进制整数*/
    for(int i=result.size()-1;i>=0;i--)
        cout<<result[i];
    cout<<endl;
}

int main(){
    string num="1f";//十六进制数
    int decimal_num=anyBinaryToDecimal(num,16);//将十六进制数转化成十进制数
    cout<<decimal_num<<endl;//打印转化后的十进制数
    decimalToAnyBinary(decimal_num,8);//将十进制数转化成八进制数,并输出结果
    return 0;
}


第二种方法:

/**
   语法:conversion(char s1[],char s2[],long d1,long d2);
   参数:s[]:原进制数字,用字符串表示
        s2[]:转换结果,用字符串表示
          d1:原进制数
          d2:需要转换到的进制数
   返回值:null
   注意:高于9的位数用大写'A'~'Z'表示,2~16位进制通过验证

*/


void conversion(char s[],char s2[],long d1,long d2)
{
    long i,j,t,num;
    char c;
    num=0;
    for (i=0;s[i]!='\0';i++)
        {
        if (s[i]<='9'&&s[i]>='0') t=s[i]-'0'; else t=s[i]-'A'+10;
        num=num*d1+t;
        }
    i=0;
    while(1)
        {
        t=num%d2;
        if (t<=9) s2[i]=t+'0'; else s2[i]=t+'A'-10;
        num/=d2;
        if (num==0) break;
        i++;
        }
    for (j=0;j<i/2;j++)
        {c=s2[j];s2[j]=s[i-j];s2[i-j]=c;}
    s2[i+1]='\0';
}



第一种方法参考博客:http://blog.csdn.net/piaojun_pj/article/details/5963325
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值