Java 实现 输入 AA 输出 AB ..输入 AZ 输出 BA 一直到输出 ZZ - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
h8743
V2EX    Java

Java 实现 输入 AA 输出 AB ..输入 AZ 输出 BA 一直到输出 ZZ

  •  
  •   h8743 2019-06-05 14:30:04 +08:00 5393 次点击
    这是一个创建于 2403 天前的主题,其中的信息可能已经有所发展或是发生改变。

    :)

    41 条回复    2019-06-08 13:37:27 +08:00
    firefffffffffly
        1
    firefffffffffly  
       2019-06-05 14:35:18 +08:00   53
    if(input == "AA") {
    System.out.println("AB");
    } else if(input == "AZ") {
    System.out.println("BA 一到输出 ZZ");
    }

    自己的作业自己做
    pcatzj
        2
    pcatzj  
       2019-06-05 14:52:17 +08:00 via Android   3
    @firefffffffffly 像一楼这么优秀的人不多了
    fzy0728
        3
    fzy0728  
       2019-06-05 14:56:10 +08:00
    @firefffffffffly 没毛病
    xmoiduts
        4
    xmoiduts  
       2019-06-05 14:56:50 +08:00 via Android
    只有我是把字母变成数值,然后+1 再变回字母吗?
    smilenceX
        5
    smilenceX  
       2019-06-05 14:57:19 +08:00   1
    可能我阅读理解不过关,没读懂题目。
    ipwx
        6
    ipwx  
       2019-06-05 14:57:21 +08:00
    一楼不要这么绝情嘛~ 我来给楼主提个醒:

    AA = 0
    AB = 1
    ...
    ZZ = 26 * 26

    剩下的楼主自己想。
    ipwx
        7
    ipwx  
       2019-06-05 14:57:52 +08:00
    不好意思,ZZ = 26 * 26 - 1
    quericy
        8
    quericy  
       2019-06-05 15:03:10 +08:00
    一楼完美断句逻辑严谨 2333

    楼主可以从 ASCII 码着手思考一下
    axbx
        9
    axbx  
       2019-06-05 15:04:02 +08:00
    题目写清楚一点吧
    mirrorman
        10
    mirrorman  
       2019-06-05 15:07:59 +08:00
    取模运算
    mirrorman
        11
    mirrorman  
       2019-06-05 15:08:41 +08:00
    相当于 26 进制加法
    maninfog
        12
    maninfog  
       2019-06-05 15:10:26 +08:00 via iPhone
    @firefffffffffly 还是不严谨阿,字符串比较要用 equals 吧
    passerbytiny
        13
    passerbytiny  
       2019-06-05 15:14:06 +08:00
    char[] chars = new char[]{A, B, ... , Z};

    for (char firstChar : chars) {
    for (char secondChar : chars ) {
    System.out.println(firstChar + secondChar );
    }
    }
    passerbytiny
        14
    passerbytiny  
       2019-06-05 15:15:48 +08:00
    擦,跑题了
    h8743
        15
    h8743  
    OP
       2019-06-05 15:28:41 +08:00
    @axbx 就是一个函数 输入 AA 输出 AB ..输入 AZ 输出 BA 一直到输出 ZZ
    hhhsuan
        16
    hhhsuan  
       2019-06-05 15:29:51 +08:00
    26 进制
    h8743
        17
    h8743  
    OP
       2019-06-05 15:30:06 +08:00
    @axbx 就是一个函数 输入 AA 输出 AB
    ..输入 AZ 输出 BA
    一直到 最大输入 ZY 输出 ZZ 输入 ZZ 时候 提示已到底
    youngfish
        18
    youngfish  
       2019-06-05 15:37:08 +08:00
    public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    String next = scanner.next();
    if (next.length() != 2) {
    System.out.println("输入值有误");
    return;
    }
    next = new StringBuilder(next).reverse().toString();
    StringBuilder result = new StringBuilder();
    int lastValue = 1;
    for (int i = 0; i < next.length(); i++) {
    lastValue = isAZ(next.charAt(i), lastValue, result);
    }
    System.out.println(result.reverse().toString());
    }

    private static int isAZ(char inputChar, int isAdd, StringBuilder result) {
    if (inputChar < 'A' || inputChar > 'Z') {
    System.out.println("输入的字符有误,请输入 A-Z");
    return 0;
    } else {
    if (isAdd == 0) {
    result.append(inputChar);
    return 0;
    }
    inputChar++;
    if (inputChar > 'Z') {
    inputChar = (char) ((inputChar - 65) % 26 + 65);
    result.append(inputChar);
    return 1;
    } else {
    inputChar = (char) ((inputChar - 65) % 26 + 65);
    result.append(inputChar);
    return 0;
    }
    }
    }
    passerbytiny
        19
    passerbytiny  
       2019-06-05 15:45:31 +08:00
    char[] inputChars = input.toCharArray();
    String output = null;
    if (input.matches("[A-Z][A-Y]"){
    output = new StringBuilder().append(inputChars [0]).append(getNextAlphabet(inputChars [1]));
    } else if (input.matches("[A-Y]Z") {
    output = new StringBuilder().append(getNextAlphabet(inputChars [0]).append("A");
    } else if (input.equals("ZZ"){
    output = "到底了";
    } else {
    output = "Invalid input!";
    }

    char getNextAlphabet(char c){
    return (char)(((int)c) + 1);
    }
    AntiGameZ
        20
    AntiGameZ  
       2019-06-05 15:51:06 +08:00
    passerbytiny
        21
    passerbytiny  
       2019-06-05 16:22:46 +08:00
    @AntiGameZ #20 这个不是严格的 26 进制,我暂时还不知道怎么搞。
    brust
        22
    brust  
       2019-06-05 16:25:21 +08:00
    字母版的 26 进制吗
    passerbytiny
        23
    passerbytiny  
       2019-06-05 16:54:26 +08:00   1
    @AntiGameZ #20 这东西要用矩阵去求取,不能用 26 进制。

    public class ExcelSheetColumnTitle {
    static Map<Integer, Character> index2titleMap = new HashMap<>();
    static {
    index2titleMap.put(1, 'A');
    index2titleMap.put(2, 'B');
    index2titleMap.put(3, 'C');
    index2titleMap.put(4, 'D');
    index2titleMap.put(5, 'E');
    index2titleMap.put(6, 'F');
    index2titleMap.put(7, 'G');
    index2titleMap.put(8, 'H');
    index2titleMap.put(9, 'I');
    index2titleMap.put(10, 'J');
    index2titleMap.put(11, 'K');
    index2titleMap.put(12, 'L');
    index2titleMap.put(13, 'M');
    index2titleMap.put(14, 'N');
    index2titleMap.put(15, 'O');
    index2titleMap.put(16, 'P');
    index2titleMap.put(17, 'Q');
    index2titleMap.put(18, 'R');
    index2titleMap.put(19, 'S');
    index2titleMap.put(20, 'T');
    index2titleMap.put(21, 'U');
    index2titleMap.put(22, 'V');
    index2titleMap.put(23, 'W');
    index2titleMap.put(24, 'X');
    index2titleMap.put(25, 'Y');
    index2titleMap.put(26, 'Z');
    }

    public String valueToTitle(int n) {
    int row = n / 26;
    int column = n % 26;
    if (column == 0) {
    row -= 1;
    column = 26;
    }

    if (row == 0) {
    return String.valueOf(index2titleMap.get(column));
    } else if (row >= 1 && row <= 26) {
    return new StringBuilder().append(index2titleMap.get(row)).append(index2titleMap.get(column)).toString();
    } else {
    return null;
    }
    }
    }
    msaionyc
        25
    msaionyc  
       2019-06-05 17:03:04 +08:00
    @passerbytiny 老哥你这 26 行 put 方法写的不累吗?万一哪行写错了怎么办
    jason19659
        26
    jason19659  
       2019-06-05 17:10:38 +08:00
    @fireffffffffly
    得用 equals
    if( "AA".equals(input)) {
    System.out.println("AB");
    } else if("AZ".equals(input)) {
    System.out.println("BA 一到输出 ZZ");
    }
    NoKey
        27
    NoKey  
       2019-06-05 17:12:24 +08:00   1
    一楼最优秀。。。
    26 楼最认真。。。
    over
    woscaizi
        28
    woscaizi  
       2019-06-05 17:20:19 +08:00 via iPhone
    转为 char 数组,直接 char +1,逢 27 进 1
    yoke123
        29
    yoke123  
       2019-06-05 17:21:31 +08:00
    秀的头皮发麻 老铁 没毛病
    vulgur
        30
    vulgur  
       2019-06-05 17:39:57 +08:00
    MineDog
        31
    MineDog  
       2019-06-05 17:47:09 +08:00 via Android
    应该是 2 位 27 进制自增返回才对
    yumenawei
        32
    yumenawei  
       2019-06-05 18:08:08 +08:00
    竟然真有老哥给答案。
    MineDog
        33
    MineDog  
       2019-06-05 18:17:24 +08:00
    想错了,还是 26 进制

    public String func (String str){
    char[] cs = str.toCharArray();
    if(cs.length!=2 || cs[0]< 'A' || cs[0] < 'Z' || cs[1]< 'A' || cs[1] > 'Z' ){
    throw new IllegalArgumentException(String.format("参数错误:%s", str));
    }
    cs[1]++;
    if(cs[1]>'Z'){
    cs[0]++;
    cs[1]='A';
    }
    if(cs[0]>'Z'){
    throw new IllegalArgumentExcption(String.format("参数错误 : %s", str));
    }
    return String.valueOf(cs[0]) + String.valueOf(cs[1]);
    }
    zjp
        34
    zjp  
       2019-06-05 18:37:53 +08:00 via Android
    通用说是字典序,不过这里不用这么麻烦
    zsdroid
        35
    zsdroid  
       2019-06-05 19:15:21 +08:00
    <?php
    //php 是世界上最好的语言
    $input = 'AA';
    echo ++$input;//AB

    $input = 'ZY';
    echo ++$input;//ZZ
    ?>
    itechify
        36
    itechify  
    PRO
       2019-06-05 19:59:57 +08:00 via Android
    @firefffffffffly 除了不用 equals,input 输入变量不在在后面防止空指针外,没挑出毛病了!
    fmumu
        37
    fmumu  
       2019-06-05 20:54:20 +08:00 via Android
    26 进制?
    small2Sun
        38
    small2Sun  
       2019-06-05 21:13:03 +08:00 via Android
    @firefffffffffly 它要输出 AB..
    wenzhoou
        39
    wenzhoou  
       2019-06-06 09:04:44 +08:00
    public static int c2i(String s) {
    return s.length() == 1 ? s.charAt(0)-'A' : c2i(s.substring(0, s.length()-1))*26 + (s.charAt(s.length()-1)-'A');
    }
    public static String i2c(int i) {
    return i < 26 ? ("" + (char)('A' + i)) : i2c(i/26) + i2c(i%26);
    }

    public static String padTo2Digit(String s) {
    return ("A" + s).substring(s.length()-1);
    }

    String input = "AA";
    System.out.println(padTo2Digit(i2c(c2i(input)+1)));
    passerbytiny
        40
    passerbytiny  
       2019-06-06 14:51:43 +08:00
    @AntiGameZ #20
    @ipwx #24
    LeetCode 不太会用,怎么用的,提交成功后貌似只能自己看,讨论区要另外创建内容。
    矩阵方式的代码,提交的时候被拒了,其测试用例要求的是 AAA 甚至更多字母都要被解析,而我那个最多支持到两位字母。后来搞了个很难以理解的方式,能支持解析 int 的全部范围。
    话说 LeetCode 貌似是为了防止 1 楼的方式,隐藏了实际的测试用例,然而用起来很不爽,要到提交的时候才知道自己跑题了。
    Aresxue
        41
    Aresxue  
       2019-06-08 13:37:27 +08:00
    26 进制,自己不能好好做作业嘛
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2479 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 218ms UTC 08:22 PVG 16:22 LAX 00:22 JFK 03:22
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86