Excel 表列名称(26进制)

给你一个整数 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
cpp 复制代码
class Solution {
public:
    string convertToTitle(int columnNumber) {
         string result;
        
        while (columnNumber > 0) {
            columnNumber--; // 将 columnNumber 减 1 以处理 0 基础问题
            char ch = 'A' + (columnNumber % 26); // 计算当前字符
            result = ch + result; // 在结果前添加字符
            columnNumber /= 26; // 进入下一位
        }
        
        return result;
    }
};

在计算之前将 columnNumber 减去 1。这是因为 Excel 列是以 1 为基数的,而运算实际上是基于 0 的。

ch 的值是 'A' 加上余数,这样可以得到对应的字符。025 的范围,表示字母 AZ

result = ch + result; 将当前字符 ch 添加到 result 的前面。这样可以保证字符顺序是从高位到低位,因为我们是从右到左进行计算的。

假设我们输入 columnNumber = 28

  1. 初始 columnNumber28

    • columnNumber--,变为 27
    • 27 % 26 = 1,所以 ch = 'A' + 1 = 'B'
    • result 现在是 "B"
    • columnNumber /= 26,变为 1
  2. 下一次循环,columnNumber1

    • columnNumber--,变为 0
    • 0 % 26 = 0,所以 ch = 'A' + 0 = 'A'
    • result 现在是 "AB"
    • columnNumber /= 26,变为 0
  3. 循环结束,返回 result,即 "AB"

创建一个映射 numToChar,用于将整数值映射到字符。键是整数,值是对应的字母。

cpp 复制代码
class Solution {
public:
    string convertToTitle(int columnNumber) {
        map<int, char> numToChar; // 创建一个映射,将数字与对应的字母联系起来
        for (int i = 0; i < 26; i++) {
            numToChar[i] = 'A' + i; 
        }
        
        string result;
        while (columnNumber > 0) {
            columnNumber--; // 将 columnNumber 减 1 以处理 0 基础问题
            int index = columnNumber % 26 ; // 获取对应的索引
            result = numToChar[index] + result; // 使用 map 查找对应的字符
            columnNumber /= 26; // 进入下一位
        }
        
        return result;
    }
};
相关推荐
郝学胜-神的一滴21 分钟前
【技术实战】500G单行大文件读取难题破解!生成器+自定义函数最优方案解析
开发语言·python·程序人生·面试
NAGNIP22 分钟前
一文搞懂CNN经典架构-AlexNet!
人工智能·算法
愤豆25 分钟前
02-Java语言核心-语法特性-注解体系详解
java·开发语言·python
是翔仔呐40 分钟前
第13章 SPI通信协议全解:底层时序、4种工作模式与W25Qxx Flash芯片读写实战
c语言·开发语言·stm32·单片机·嵌入式硬件·学习·gitee
2401_878530211 小时前
自定义内存布局控制
开发语言·c++·算法
专注VB编程开发20年1 小时前
PNG、GIF透明游戏角色人物输出一张图片技巧,宽度高度读取
算法
wjs20241 小时前
SQLite 子查询
开发语言
AndrewMe82111 小时前
detailed-docx:一个能保住格式的 Word 文档操作库
开发语言·python·word
CoderCodingNo1 小时前
【CSP】CSP-J 2025真题 | 异或和 luogu-P14359 (相当于GESP六级水平)
算法
IT方大同1 小时前
RT_thread(RTOS实时操作系统)线程的创建与切换
c语言·开发语言·嵌入式硬件