• 河南省第四届ACM省赛(T1) 序号互换


    问题 A: 序号互换

    时间限制: 1 Sec  内存限制: 128 MB
    难度1

    题目描述

    Dr.Kong设计了一个聪明的机器人卡多,卡多会对电子表格中的单元格坐标快速计算出来。单元格的行坐标是由数字编号的数字序号,而列坐标使用字母序号。观察字母序号,发现第1列到第26列的字母序号分别为A,B,…,Z,接着,第27列序号为AA,第28列为AB,依此类推。

    若给Dr.Kong的机器人卡多一个数字序号(比如32),它能很快算出等价的字母序号(即AF),若给机器人一个字母序号(比如AA)),它也能很快算出等价的数字序号(27),你能不能与卡多比试比试,看谁能算得更快更准确。

    输入

    第一行: N        表示有多少组测试数据。 

    接下来有N行,    每行或者是一个正整数,或者是一个仅由大写字母组成的字符串。

    输出

    对于每一行测试数据,输出一行。如果输入为一个正整数序号,则输出等价的字母序号;如果输入为字符串,则输出等价的数字序号。

    样例输入

    4
    27
    G
    AA
    ALK
    

    样例输出

    AA
    7
    27
    999

    模拟

     1 #include<math.h>
     2 #include<stdio.h>
     3 #include<string.h>
     4 char a[11000],b[11000];
     5 int huan(int a) {
     6     memset(b,0,sizeof(b));
     7     int k,l,i;
     8     k=a;
     9     l=0;
    10     while(a) {
    11         if(a>26)
    12             b[l++]='A'+a%26-1;
    13         else
    14             b[l++]='A'+a-1;
    15         a=a/26;
    16     }
    17     for(i=l-1; i>=0; i--)
    18         printf("%c",b[i]);
    19     printf("
    ");
    20     //puts(b);
    21 }
    22 int main() {
    23     int t,i,j,l,k,sum;
    24     scanf("%d",&t);
    25     getchar();
    26     while(t--) {
    27         memset(a,0,sizeof(a));
    28         scanf("%s",a);
    29         sum=0;
    30         l=strlen(a);
    31         for(i=0; i<l; i++) {
    32             if(a[i]>='0'&&a[i]<='9') {
    33                 sum=sum*10+a[i]-'0';
    34             }
    35         }
    36         //    printf("%d
    ",sum);
    37         if(sum>0) {
    38             huan(sum);
    39         } else {
    40             k=0;
    41             for(i=l-1; i>=0; i--) {
    42                 sum+=(a[i]-'A'+1)*pow(26,k++);
    43             }
    44             printf("%d
    ",sum);
    45         }
    46     }
    47     return 0;
    48 }
     
  • 相关阅读:
    python 端口扫描仪
    [ruby on rails] 深入(1) ROR的一次request的响应过程
    [ruby on rails] 跟我学之(10)数据输入验证
    [ruby on rails] 跟我学之(9)删除数据
    [ruby on rails] 跟我学之(8)修改数据
    [ruby on rails] 跟我学之(7)创建数据
    BZOJ 2301 [HAOI2011]Problem b (分块 + 莫比乌斯反演)
    BZOJ 2005 [Noi2010]能量采集 (数学+容斥 或 莫比乌斯反演)
    BZOJ 1497 [NOI2006]最大获利 (最小割)
    BZOJ [FJOI2007]轮状病毒 (找规律)
  • 原文地址:https://www.cnblogs.com/ljmzzyk/p/6723098.html
Copyright © 2020-2023  润新知