0

我需要一个 java 方法,它接受一个整数,然后递增它并给你相应的字母字符。像这样的东西:

public String getAlpha(Integer number) {
   ...
}

因此,如果我传递的number值 equal0那么它应该递增并返回 letter a。如果我通过它,25那么它应该返回这封信z。如果我将数字传递给它,26那么它应该返回aa。如果我将数字传递给它,27那么它应该返回ab等等。

alpha 几乎模拟了 excel 工作表列的表示方式,我需要做的就是通过传递一个数字从方法中获取 alpha 值。除了返回的字符串getAlpha必须是最大15字符和最小字符外,没有设置限制1

4

3 回答 3

1

我相信这会做你想要的,我不知道它是否可以更有效地完成:

static void printCode(int code) {
  final StringBuilder buffer = new StringBuilder();
  do {
    final int digit = (code - 1) % 26;
    buffer.insert(0, (char)(digit + 'a'));
    code = (code - digit - 1) / 26;
  } while (code > 0);
  System.out.println(buffer);
}
于 2012-08-21T12:56:43.590 回答
0

这是在 Java 中从 0 到 25 之间的数字生成 a - z 的方式:

protected static String getLetter(int code) {
    if (code >= 0 && code <= 25)
        return "" + (char) (code  + 'a');
    else
        throw new IllegalArgumentException("char code is out of bound: " + code);
}

其余的只是模数学。

于 2012-08-21T12:32:13.370 回答
0

它与 Excel 列命名相同:

public class Calculator {

    private static String[] letters = new String[]{
        "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"
    };

    public static void main(String[] args) {
        System.out.println(calculate(731));
    }

    public static String calculate(int row) {
        return calculateRecursive(row - 1, "");
    }

    private static String calculateRecursive(int row, String res) {
        String val = letters[row % letters.length] + res;
        int i = row / letters.length;
        if(row >= letters.length) {
            return calculateRecursive(i - 1, val);
        }
        return val;

    }
}
于 2017-05-17T09:45:15.473 回答