关于leetcode:每日一练41Excel表列名称

32次阅读

共计 910 个字符,预计需要花费 3 分钟才能阅读完成。


title: 每日一练(41):Excel 表列名称

categories:[剑指 offer]

tags:[每日一练]

date: 2022/04/13


每日一练(41):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 <= 231 – 1

起源:力扣(LeetCode)

链接:https://leetcode-cn.com/probl…

办法一:从 1 开始的 26 进制转换

思路剖析

失常的 26 进制显示数字应该是 0 -25,而本题是 1 -26,那么在解决每一位之前进行减一,即可变成失常进制转换操作。

string convertToTitle(int columnNumber) {
    string ans;
    do {
        columnNumber--;
        ans = char(columnNumber % 26 + 'A') + ans;// 失去字符列名称
        columnNumber /= 26;
    } while(columnNumber > 0);
    return ans;
}

办法二:取余 + 反转

思路剖析

当余数为 0 时,咱们不能取 @而是应该取 Z

string convertToTitle(int columnNumber) {
    string ans;
    while (columnNumber) {
        int remainder = columnNumber % 26;
        if (remainder == 0) { // 如果余数是 0,就像上一位借个 1(26)进去,让余数强行等于 26
            remainder = 26;
            columnNumber -= 26;
        }
        ans.push_back(remainder + 'A' - 1);
        columnNumber /= 26;
    }
    reverse(ans.begin(), ans.end());// 字符串倒序
    return ans;
}

正文完
 0