题目链接

题目大意:

人们常用的电子表格软件(比如: Excel)采用如下所述的坐标系统:

第一列被标为 A,第二列为 B,以此类推,第 262626 列为 Z。接下来为由两个字母构成的列号: 第 272727 列为 AA,第 282828 列为 AB ⋯\cdots⋯ 在标为 ZZ 的列之后则由三个字母构成列号,如此类推。

行号为从 1 开始的整数。

单元格的坐标由列号和行号连接而成。比如,BC23 表示位于第 55 列 23 行的单元格。

有时也会采用被称为 RXCY 的坐标系统,其中 X 与 Y 为整数,坐标 (X,Y) 直接描述了对应单元格的位置。比如,R23C55 即为前面所述的单元格。

您的任务是编写一个程序,将所给的单元格坐标转换为另一种坐标系统下面的形式。

解题思路:

  1. 首先判断是哪一种表示方法,我用的类似于枚举样式:

    bool check()
    {
    int n;
    n = strlen(s);
    if(s[0] == 'R')
    {
    int j = 1;
    while(check_count(s[j]) && j < n) j ++ ;
    if(j == 1) return false; if(s[j] == 'C') return true;
    } return false;
    }
  2. 写转换函数change1/change2:
    void change1()
    {
    string a1 = "", a2 = "";
    int n = strlen(s);
    int i = 1;
    for ( ; i < n; i ++ )
    {
    if (!check_count(s[i])) break;
    a1 += s[i];
    }
    int res = 0;
    i ++;
    for( ; i < n; i ++ )
    {
    res = res * 10 + s[i] - '0';
    } while (res)
    {
    char p;
    int t = res % 26;
    if(!t)
    p = 'Z';
    else
    p = t - 1 + 'A';
    a2 = p + a2 ;
    if(!t) res = res / 26 - 1;
    else res = res / 26;
    } cout << a2 << a1 << '\n';
    } void change2()
    {
    int n;
    n = strlen(s);
    int i = 0;
    string s1 = "R", s2 = "C";
    for( ; i < n; i ++ )
    {
    if(check_count(s[i])) break;
    } for( ; i < n; i ++ )
    {
    s1 += s[i];
    } string t = "";
    for(int i = 0; i < n; i ++ )
    {
    if (check_count(s[i])) break;
    t += s[i];
    } int res = 0;
    for(int i = 0; i < t.size(); i ++ )
    {
    res = res * 26 + t[i] - 'A' + 1;
    } string tt = to_string(res);
    s2 += tt;
    cout << s1 << s2 << '\n';
    }

本题踩的坑:

首先这个26进制非我们常见的二进制,他不可以出现0.就。出现0代表他是“Z”,还有我们不能使其是26的倍数,这里用一个特判,如果是26的倍数,我们将其减一就好了。如:

while (res)
{
char p;
int t = res % 26; //0代表他是最后一个字母
if(!t)
p = 'Z';
else
p = t - 1 + 'A';
a2 = p + a2 ;
if(!t) res = res / 26 - 1; //不能是26的整数倍,因为该进制数中不可以出现0
else res = res / 26;
}

本题AC代码:

#include <bits/stdc++.h>

using namespace std;

char s[100];

bool check_count(char a)
{
if (a >= '0' && a <= '9') return true;
return false;
} void change1()
{
string a1 = "", a2 = "";
int n = strlen(s);
int i = 1;
for ( ; i < n; i ++ )
{
if (!check_count(s[i])) break;
a1 += s[i];
}
int res = 0;
i ++;
for( ; i < n; i ++ )
{
res = res * 10 + s[i] - '0';
} while (res)
{
char p;
int t = res % 26; //0代表他是最后一个字母
if(!t)
p = 'Z';
else
p = t - 1 + 'A';
a2 = p + a2 ;
if(!t) res = res / 26 - 1; //不能是26的整数倍,因为该进制数中不可以出现0
else res = res / 26;
} cout << a2 << a1 << '\n';
} void change2()
{
int n;
n = strlen(s);
int i = 0;
string s1 = "R", s2 = "C";
for( ; i < n; i ++ )
{
if(check_count(s[i])) break;
} for( ; i < n; i ++ )
{
s1 += s[i];
} string t = "";
for(int i = 0; i < n; i ++ )
{
if (check_count(s[i])) break;
t += s[i];
} int res = 0;
for(int i = 0; i < t.size(); i ++ )
{
res = res * 26 + t[i] - 'A' + 1;
} string tt = to_string(res);
s2 += tt;
cout << s1 << s2 << '\n';
} bool check()
{
int n;
n = strlen(s);
if(s[0] == 'R')
{
int j = 1;
while(check_count(s[j]) && j < n) j ++ ;
if(j == 1) return false; if(s[j] == 'C') return true;
} return false;
} void solved()
{
cin >> s;
if(check())
{
change1();
}
else
{
change2();
}
} int main()
{
int t;
cin >> t;
while (t--)
{
solved();
} return 0;
}

1B踩坑大王的更多相关文章

  1. Faster_Rcnn在windows下运行踩坑总结

    Faster_Rcnn在windows下运行踩坑总结  20190524 今天又是元气满满的一天! 1.代码下载 2.编译 3.下载数据集 4.下载pre-train Model 5.运行train ...

  2. Spark踩坑记——Spark Streaming+Kafka

    [TOC] 前言 在WeTest舆情项目中,需要对每天千万级的游戏评论信息进行词频统计,在生产者一端,我们将数据按照每天的拉取时间存入了Kafka当中,而在消费者一端,我们利用了spark strea ...

  3. Spark踩坑记——数据库(Hbase+Mysql)

    [TOC] 前言 在使用Spark Streaming的过程中对于计算产生结果的进行持久化时,我们往往需要操作数据库,去统计或者改变一些值.最近一个实时消费者处理任务,在使用spark streami ...

  4. 【踩坑速记】二次依赖?android studio编译运行各种踩坑解决方案,杜绝弯路,总有你想要的~

    这篇博客,只是把自己在开发中经常遇到的打包编译问题以及解决方案给大家稍微分享一下,不求吸睛,但求有用. 1.大家都知道我们常常会遇到dex超出方法数的问题,所以很多人都会采用android.suppo ...

  5. NPOI导出Excel (C#) 踩坑 之--The maximum column width for an individual cell is 255 charaters

    /******************************************************************* * 版权所有: * 类 名 称:ExcelHelper * 作 ...

  6. 我的微信小程序入门踩坑之旅

    前言 更好的阅读体验请:我的微信小程序入门踩坑之旅 小程序出来也有一段日子了,刚出来时也留意了一下.不过赶上生病,加上公司里也有别的事,主要是自己犯懒,就一直没做.这星期一,赶紧趁着这股热乎劲,也不是 ...

  7. router路由去掉#!的踩坑记

    项目中在研究去掉router#!的过程中的踩坑过程.

  8. vue+ vue-router + webpack 踩坑之旅

    说是踩坑之旅 其实是最近在思考一些问题 然后想实现方案的时候,就慢慢的查到这些方案   老司机可以忽略下面的内容了 1)起因  考虑到数据分离的问题  因为server是express搭的   自然少 ...

  9. 记jQuery.fn.show的一次踩坑和问题排查

    最近很少已经很少用jQuery,因为主攻移动端,常用Zepto,其实很多细节和jQuery并不一样.最近又无意中接触到了PC的需求和IE6, 使用了jQuery,刚好踩坑了,特意记录一下. 本文内容如 ...

  10. WebForm路由踩坑 ajax请求多次

    WebForm路由踩坑 再次接触Asp.Net WebForm已是4年后的今天,源起新入职的公司,一个老的项目. Web接触的少,那就多动手写写. WebForm1.aspx <body> ...

随机推荐

  1. AtCoder Beginner Contest 265(D-E)

    D - Iroha and Haiku (New ABC Edition) 题意: 找一个最少含有三个点的区间,将区间分成三块,三块的和分别为p,q,r,问是否存在这样的区间 题解:先预处理一遍前缀和 ...

  2. 报错:①Tog goal specified requires a project to execute but there is no POM in this directory......②说类HelloWorld是公共的, 应在名为 HelloWorld.java 的文件中声明 public class HelloWorld......

    在运行Maven的命令时,在DOS窗口里面必须把目录切换到项目的根部,要不然命令是找不到目的地. 下图是错误示范,项目在Demo02这个目录里,就必须将目录切换到Demo02下,否则DOS窗口只有飘红 ...

  3. Linux KVM创建虚拟机

    原博文(https://www.cnblogs.com/supermao12/p/16382767.html) 开启虚拟化 KVM需要64位操作系统 [root@localhost 4.18.0-19 ...

  4. 使用 Elastic 技术栈构建 K8S 全栈监控 -4: 使用 Elastic APM 实时监控应用性能

    文章转载自:https://www.qikqiak.com/post/k8s-monitor-use-elastic-stack-4/ 操作步骤 apm-servver连接es使用上一步创建的secr ...

  5. fastdfs-zyc管理FastDFS的web界面

    俩压缩包根据大小重命名以下,按图片所示 把1_fastdfs-zyc.7z重命名为fastdfs-zyc.7z.001 把2_fastdfs-zyc.7z重命名为fastdfs-zyc.7z.002 ...

  6. Docker 容器日志管理

    Docker 日志分为两类: Docker 引擎日志(也就是 dockerd 运行时的日志), 容器的日志,容器内的服务产生的日志. 一 .Docker 引擎日志 Docker 引擎日志一般是交给了 ...

  7. 【前端必会】webpack 插件,前进路绕不过的障碍

    背景 webpack的使用中我们会遇到各种各样的插件.loader. webpack的功力主要体现在能理解各个插件.loader的数量上.理解的越多功力越深 开始 https://webpack.do ...

  8. Go微服务实战 - 用户服务开发(gRPC+Protocol Buffer)

    概要 用户服务基本是每个互联网产品里必备的一个服务了,因为没有用户基本是什么也干不了.所以他的重要性不言而喻.本文主要介绍下如何开发一个用户微服务,以及他的详细开发流程. 目录 Go微服务实战 - 从 ...

  9. 关于vmware虚拟机的ova/ovf转换成aws上的AMI镜像

    很多时候,我们会有这样的需求,需要将DC中vmware虚拟化的服务器,迁移到aws上,我们就得先将vmware虚拟机导出,然后转换 关于vmvare虚拟的导出备份,一般有ova(Open Virtua ...

  10. 2. 单主机 Elasticsearch 双节点或多节点集群环境部署

    我已经买了一年的腾讯云轻量级服务器,并且安装好了ES,也做了一些系统配置,比如 修改vm.max_map_count.修改文件描述符数量 同时,也用ES安装目录下的 bin/elasticsearch ...