`
第一种方法
``
#include
#include
using namespace std;
void zhuanhuan(int n,int r) {
int a, b;
a = n / r;
b = n % r;
if (a == 0) {
if (n < 0)
cout << “-” << hex << uppercase << -b;
else
cout << hex << uppercase << b;
return;
}
zhuanhuan(a, r);
if (b < 0)
cout << hex << uppercase << -b;
else
cout << hex << uppercase << b;
}
int main()
{
int n,r;
while(cin >>n>>r) {
zhuanhuan(n, r);
cout << endl;
}
return 0;
}
> 第二种方法
#include
using namespace std;
int main()
{
long n;
int k;
int p,c,m=0,i,a;
while(cin>>n>>p)
{
a=10;
if(n<0)
{
a*=-1;
n*=-1;
}
m=0;
int s[100]={0};
while(n!=0)//进制转换,结果存入数组中s[m]
{
c=n%p;
n=n/p;
s[m]=c;
m++;
}
if(a<0)
cout<<"-";
for(k=(m-1);k>=0;k–)
{
if(s[k]>=10)
cout<<(char) (s[k]+55);
else
cout<<s[k];
}
cout<<endl;
}
return 0;
}