当前位置: 首页 > article >正文

力扣:168. Excel表列名称(Python3)

题目:

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

例如:

A -> 1
B -> 2
C -> 3
...
Z -> 26
AA -> 27
AB -> 28 
...

来源:力扣(LeetCode)
链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

示例:

示例 1:

输入:columnNumber = 1
输出:"A"


示例 2:

输入:columnNumber = 28
输出:"AB"


示例 3:

输入:columnNumber = 701
输出:"ZY"

示例4:

输入:columnNumber = 2147483647

输出:"FXSHRXW"

解法:

首先建立1~26和A~Z的对应,接着设结果为col,初始化为空,然后依次在col头部添加字符,添加的循环类似于进制转换,先求余,在整除。

有1处细节,拿52举例,先-1,接着对26求余,然后+1,再整除26。这样的好处是可以避免52对26求余得0的问题,而且-1之后整除的结果更准确,避免26倍数问题。

代码:

class Solution:
    def convertToTitle(self, columnNumber: int) -> str:
        dic = {1: 'A', 2: 'B', 3: 'C', 4: 'D', 5: 'E', 6: 'F', 7: 'G', 8: 'H', 9: 'I', 10: 'J', 11: 'K', 12: 'L', 13: 'M', 14: 'N', 15: 'O', 16: 'P', 17: 'Q', 18: 'R', 19: 'S', 20: 'T', 21: 'U', 22: 'V', 23: 'W', 24: 'X', 25: 'Y', 26: 'Z'}
        col = ''
        while columnNumber > 0:
            columnNumber -= 1
            col = dic[columnNumber % 26 + 1] + col
            columnNumber //= 26
        return col


http://www.kler.cn/a/132368.html

相关文章:

  • 【AtCoder】Beginner Contest 380-F.Exchange Game
  • 15. Python中的os.path模块/路径操作相关
  • D3中颜色的表示方法大全
  • 初识进程——Linux
  • if 语句 和 case 语句
  • 【GPTs】Ai-Ming:AI命理助手,个人运势与未来发展剖析
  • Qt退出界面
  • 微信小程序Error: ENOENT: no such file
  • Django学习日志04
  • py 动态输入参数
  • 什么是跨境电子商务综合试验区?成为综试区有何好处?
  • 现货黄金职业交易员怎么使用技术分析?
  • 【数据结构 | 链表】leetcode 2. 两数相加
  • Os-ByteSec
  • Oracle 存储过程数据插入临时表慢以及SQL语句查询慢
  • 【第2章 Node.js基础】2.7 Node.js 的流(一)可写流
  • 互联网上门预约洗衣洗鞋店小程序;
  • java的包装类
  • 【Mysql学习笔记】1 - Mysql入门
  • 【Linux】Ubuntu16.04下安装python高版本--源码安装
  • Docker Golang 开发环境搭建指南
  • AODNet
  • 【docker启动的Jenkins时,遇到时区问题处理】
  • vscode编写verilog的插件【对齐、自动生成testbench文件】
  • SQLMAP --TAMPER的编写
  • 记录一些涉及到界的题