闯关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

相关推荐
PAK向日葵1 小时前
【算法导论】PDD 0817笔试题题解
算法·面试
地平线开发者4 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶
快乐的划水a4 小时前
组合模式及优化
c++·设计模式·组合模式
地平线开发者4 小时前
开发者说|EmbodiedGen:为具身智能打造可交互3D世界生成引擎
算法·自动驾驶
星星火柴9365 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑6 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
C++、Java和Python的菜鸟7 小时前
第六章 统计初步
算法·机器学习·概率论
Cx330❀7 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散1127 小时前
01数据结构-Prim算法
数据结构·算法·图论
起个昵称吧8 小时前
线程相关编程、线程间通信、互斥锁
linux·算法