关于10进制与26进制转换的一道ACM竞赛题,求解答,最好用C语言,C++也可以
问题描述见图片要求输入:每组测试数据均是两个code26数据,之包含大写字母输出:输出password格式如下样例:输入:AAAADHBCEDRWUHDDAAAAA输出:...
问题描述见图片要求输入:每组测试数据均是两个code26数据,之包含大写字母输出:输出password格式如下样例:输入:AAAADH BCEDRW UHDD AAAAA输出:BFLXYZD
展开
2个回答
展开全部
#include <iostream>
#include <string>
#include <cmath>
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<<key<<endl;
}
追问
能改成循环输入样例就更好了
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
//用C编译器,不要用C++编译器
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
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;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |