题目描述:
大家都见过的excel列表或者说二维数组,对于行和列的描述我们给出以下两种方式:
1.RxCy
型,R代表row,C代表column,x和y分别表示两个整数。
2.Mx
型,M表示一个由大写字母表示的字符串,A规定为1,Z规定为26,而AA规定为27,AZ规定为52,依次类推,代表column。x表示一个整数,代表row
现在需要你实现这两种表达方式的转换。
题解:
其实就是一个26进制的转换问题,不过如果不用sscanf可能会很麻烦…QAQ
AC代码:
#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<vector>
using namespace std;
void change(int n)
{
if(!n) return;
change((n - 1) / 26);
putchar('A' + (n - 1) % 26);
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int r,c;
char a[10005];
scanf("%s",a);
if(sscanf(a,"R%dC%d",&r,&c) == 2){
change(c);
printf("%d\n",r);
}
else{
char b[10005];
sscanf(a,"%[A-Z]%d",b,&r);
int cnt = 1,sum = 0,len = strlen(b);
for(int i = len - 1;i >= 0;i--){
sum += (b[i] - 'A' + 1) * cnt;
cnt *= 26;
}
printf("R%dC%d\n",r,sum);
}
}
return 0;
}