杭电oj 2031

Problem Description

输入一个十进制数N,将它转换成R进制数输出。

Input

输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<>10)。

Output

为每个测试实例输出转换后的数,每个输出占一行。如果R大于10,则对应的数字规则参考16进制(比如,10用A表示,等等)。

Sample Input

 

7 2 23 12 -4 3

Sample Output

 

111 1B -11

/*
string str 当数组用 ,s.insert(s.begin(),i) ,在头处插 
*/ 

/*
string str 当数组用 ,s.insert(s.begin(),i) ,在头处插 
*/ 
#include <iostream>
#include <string>
#include <cstring>
#include <algorithm>
using namespace std;
int main(void)
{
    string str="0123456789ABCDEF";
    int n,m;
    while(cin>>n>>m){
        string s;
        if(n<0)cout<<"-";
        n=abs(n);
        while(n){
            s.insert(s.begin(),str[n%m]);
            n/=m;
        }
        cout<<s<<endl;
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/qing_feng__/article/details/86760900