闯关leetcode——168. Excel Sheet Column Title

大纲

题目

地址

https://leetcode.com/problems/excel-sheet-column-title/description/

内容

Given an integer columnNumber, return its corresponding column title as it appears in an Excel sheet.

For example:

A -> 1

B -> 2

C -> 3

...

Z -> 26

AA -> 27

AB -> 28

...

Example 1:

Input: columnNumber = 1

Output: "A"

Example 2:

Input: columnNumber = 28

Output: "AB"

Example 3:

Input: columnNumber = 701

Output: "ZY"

Constraints:

  • 1 <= columnNumber <= 231 - 1

解题

这题就是要将整型数字转换成EXCEL风格的26进制表达。除了二进制,所有进制问题都是取模再除法,从低向高位计算。但是这题有个小陷阱,就是它的数值关系中并不存在0。这样我们就需要做个转换,将数字值减少一,再去做取模或者除法。这样取模为0,就是A。27减去1得到26,取模为0,则低位为A。高位26/26等于1,1再减去1得到0,取模得到0,这样高位就为A。于是27表达为AA。

cpp 复制代码
#include <string>
using namespace std;

class Solution {
public:
    string convertToTitle(int columnNumber) {
        string result;
        int base = 26;

        while (columnNumber > 0) {
            columnNumber--;
            result = char('A' + columnNumber % base) + result;
            columnNumber = columnNumber / base;
        }

        return result;
    }
};

代码地址

https://github.com/f304646673/leetcode/tree/main/168-Excel-Sheet-Column-Title/cplusplus

相关推荐
weisian15115 小时前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao15 小时前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
ytttr87315 小时前
MATLAB SIFT图像配准实现
算法·机器学习·matlab
小饕15 小时前
从 Word2Vec 到多模态:词嵌入技术的演进全景
人工智能·算法·机器学习
海参崴-15 小时前
AVL树完整实现与深度解析
算法
一个爱编程的人15 小时前
一个数是不是素数
数据结构·算法
Hui_AI72015 小时前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
lwf00616415 小时前
FFM (Field-aware Factorization Machine) 学习日记
算法·机器学习
南宫萧幕15 小时前
HEV能量管理控制算法实战:从MPC/RL理论基础到Simulink闭环建模
算法·matlab·汽车·控制·pid
charlie11451419115 小时前
通用GUI编程技术——图形渲染实战(三十八)——顶点缓冲与输入布局:GPU的第一个三角形
开发语言·c++·学习·图形渲染·win32