任意进制转化 函数 模板(一)

虽然说是任意进制,但是等24个字母用完了,就尴尬,如果题目给出其他字符表示的话加个判断即可。36进制有点变态了,应该够用。

 #include<iostream>
#include<algorithm>
using namespace std;
string solve(int a,int b);
bool flag;
int main()
{
        int  x,y;
        cin>>x>>y;
        cout<<solve(x,y)<<endl;
        return 0;
}
string solve(int a,int b)
{
    string d;
    d.clear();
    int i=0;
    char c;
    while(a%b!=a)
    {
        i=a%b;
        if(i>=10) c=char(i+55);
    // else   if( ....) c=char(i+?) 当26个字符表示不了时可以选择其他字符表示。
        else c=i+'0';
        a=a/b;
       d.push_back(c);
    }
    if(a>=10) c=char(a+55);
    //  else  if( ....) c=char(i+?)
    else c=a+'0';
    d.push_back(c);
    reverse(d.begin(),d.end());
    return d;
}
posted @ 2019-05-20 23:56  风骨散人  阅读(90)  评论(0编辑  收藏  举报