LeetCode刷题笔记第168题:Excel表列名称

LeetCode刷题笔记第168题:Excel表列名称

题目:

给你一个整数 columnNumber ,返回它在 Excel 表中相对应的列名称。

例如:

A -> 1

B -> 2

C -> 3

...

Z -> 26

AA -> 27

AB -> 28

...

想法:

类似十进制转二进制,这里是1-26,要使用26进制则需要将1-26改为0-25。具体做法将输入的整数除以26得到的余数为个位数上的数值,再次除以26得到十位数上的数值依次类推,最终获得每个位数上的数值,再将这些数值对应的字符连接即为最终结果字符串

复制代码
class Solution:
    def convertToTitle(self, columnNumber: int) -> str:
        result = []
        while columnNumber>0:
            columnNumber -= 1  # 此处为了将数值改为26进制数
            result.append(chr(columnNumber % 26 + ord("A")))  # 获得当前位置上的字符并添加入字符串列表
            columnNumber //= 26  # 获得除数进行下一轮计算
        return "".join(result[::-1])  # 字符串列表中存储的是倒叙的字符

上述方法的

时间复杂度:O(log26 columnNumber)

空间复杂度:O(1)

相关推荐
qq_4335545418 分钟前
C++ 单调栈
数据结构·c++·算法
向前阿、20 分钟前
数据结构从基础到实战——排序
c语言·开发语言·数据结构·程序人生·算法
biubiubiu070626 分钟前
Ubuntu学习笔记
笔记·学习·ubuntu
2401_841495641 小时前
【语音识别】混合高斯模型
人工智能·python·算法·机器学习·语音识别·gmm·混合高斯模型
码上零乱1 小时前
跟着小码学算法Day19:路径总和
java·数据结构·算法
凉、介1 小时前
ARM 总线技术 —— APB
arm开发·笔记·学习
爱奥尼欧1 小时前
【Linux笔记】网络部分——网络层IP协议
linux·网络·笔记
天选之女wow2 小时前
【代码随想录算法训练营——Day53】图论——110.字符串接龙、105.有向图的完全可达性、106.岛屿的周长
算法·深度优先·图论
安迪西嵌入式2 小时前
数据平滑处理算法03——中心移动平均
java·前端·算法
CN-Dust3 小时前
【C++】2025CSP-J第二轮真题及解析
开发语言·c++·算法