#include <bits/stdc++.h>
#include <random>
#include<iostream>
#include<string.h>
#include<stdio.h>
typedef long long ll;
using namespace std;
const int maxn = 2e6+555;
const int MOD = 1000000007;
void change(string s1,string &s2,int d1,int d2){
int len = s1.size();
ll sum = 0;
int t;
for(int i=0;i<len;i++){
if(s1[i]>='0'&&s1[i]<='9'){
t=s1[i]-'0';
}
else{
t=s1[i]-'A'+10;
}
sum=d1*sum+t;
}
s2="";
while(sum){
t = sum%d2;
sum=sum/d2;
if(t>=0&&t<=9){
s2=char(t+'0')+s2;
}
else{
s2=char('A'+t-10)+s2;
}
//cout<<s2<<endl;
}
}
int main()
{
//srand(time(NULL));
//freopen("data.in","r",stdin);
string s1,s2;
int d1,d2;
s1="100";
d1=10;
d2=2;
change(s1,s2,d1,d2);
cout<<s2<<endl;
/*
说明:
s1:代表要进行转换的原字符串
s2:代表进制转换后的字符串
d1: 原字符串的进制
d2:需要转换的进制
*/
return 0;
}
C++ 进制转换
最新推荐文章于 2023-03-18 07:14:40 发布