关于10进制与26进制转换的一道ACM竞赛题,求解答,最好用C语言,C++也可以

2024-11-12 11:07:25
推荐回答(2个)
回答(1):

#include 
#include 
#include 
using namespace std;

long long fun(string a){
long long s=0;
for(int i=0;a[i]!='\0';i++)
s+=(a[i]-65)*pow(26,a.length()-1-i);
return s;
}

int main(){
long long s=0;
string a[3],key;
for(int i=2;i&&cin>>a[i];i--)
s+=fun(a[i]);
while(s!=0){
key=char(s%26+65)+key;
s/=26;
}
cout<}

回答(2):

//用C编译器,不要用C++编译器
#include 
#include 
#include 
#include 
char  mask[]="ABCDEFGHIJKLMNOPQRSTUVWXYZ";
int s26toi10(char *s){
char *p=s;
int l=strlen(s);
float sum=0;
while(*p)
sum+=(*p++-65)*pow(26,--l);
return (int)sum;
}
char* i10tos26(const int num){
int l=num,i=0;
while(l /= 26)
i++;
char *dest=(char*)malloc(i+1);
l=num;
while(l){
int s = l % 26;
l /= 26;
dest[i--]=mask[s];
}
return dest;
}
int main()
{
char *inputstr1="DH";
char *inputstr2="BCE";
int dec=s26toi10(inputstr1)+s26toi10(inputstr2);
//printf("%d",dec);
char *s=i10tos26(dec);
printf(s);
free(s);
return 0;
}