Codeforces Beta Round #1B Spreadsheets

题目描述:
大家都见过的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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CUCKyrie

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值