十进制转化为s进制
#include <iostream>
using namespace std;
const int N=100000;
string a;
string p="0123456789abcdef";
int main()
{
int n,s;//n为需要转换的数,s是转换成s进制
// int i=0;//记录长度
cin >> n >> s;
while(n!=0)
{
int m=n%s;//记录余数
a+=p[m];//存入数组中
// i++;
n/=s;
}
// for(int j=i-1;j>=0;j--) cout << a[j];
for(int i=a.size()-1;i>=0;i--) cout << a[i];
}//十进制转换为s进制
p进制转化为十进制
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
string s;//将需要转换的存入字符串即可
int p,j=0;//p为本串的进制 j存第几位
long long sum=0;//防止int存不下
cin >> s >> p;
for(int i=s.size()-1;i>=0;i--)//从个位开始判断
{
int num=0;
if(s[i]>='0'&&s[i]<='9') num=s[i]-'0';
else num=s[i]-55;//面对16进制情况
sum+=num*pow(p,j);//可数学推导
j++;
}
cout << sum;
}//将p进制的转换为十进制
新增:十进制转r进制
#include <iostream>
using namespace std;
int main()
{
int n,r;
char str[30];
cin >> n >> r;//r为需要转换的进制
itoa(n,str,r);
cout << str;
}
r进制转换为10进制
#include <iostream>
#include <string>
using namespace std;
int main()
{
int n,r;
string str;//char str[30]
cin >> str >> r;//r为str的进制
n=stoi(str,0,r);//0为需要转换的起始位置
cout << n;
}