Excel 表列名称
题目描述
给你一个整数 columnNumber ,返回它在 Excel 表中相对应的列名称。
例如:
A -> 1
B -> 2
C -> 3
...
Z -> 26
AA -> 27
AB -> 28
...
示例 1:
输入:columnNumber = 1
输出:"A"
示例 2:
输入:columnNumber = 28
输出:"AB"
示例 3:
输入:columnNumber = 701
输出:"ZY"
示例 4:
输入:columnNumber = 2147483647
输出:"FXSHRXW"
提示:
1 <= columnNumber <= 2^31^ - 1
尝试做法
java
class Solution {
public String convertToTitle(int columnNumber) {
StringBuilder sb = new StringBuilder();
while(columnNumber != 0){
--columnNumber;
int temp = columnNumber % 26;
sb.append((char)(temp + 'A'));
columnNumber /= 26;
}
return sb.reverse().toString();
}
}
按顺序获取位数即可
推荐做法
java
public String convertToTitle(int n) {
StringBuilder sb = new StringBuilder();
while (n > 0) {
int c = n % 26;
if(c == 0){
c = 26;
n -= 1;
}
sb.insert(0, (char) ('A' + c - 1));
n /= 26;
}
return sb.toString();
}
作者:windliang
链接:https://leetcode.cn/problems/excel-sheet-column-title/solutions/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
也可以,用sb.insert()来避免字符串最后的反转。
若没有n--,则要注意处理余数为零的情况。