您的位置:首页 > 新闻 > 会展 > 正规的代练接单平台_网站域名注册费用_西安网站建设公司排行榜_长尾关键词挖掘工具

正规的代练接单平台_网站域名注册费用_西安网站建设公司排行榜_长尾关键词挖掘工具

2024/10/7 4:20:54 来源:https://blog.csdn.net/Ct314/article/details/142682397  浏览:    关键词:正规的代练接单平台_网站域名注册费用_西安网站建设公司排行榜_长尾关键词挖掘工具
正规的代练接单平台_网站域名注册费用_西安网站建设公司排行榜_长尾关键词挖掘工具

给你一个整数 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

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,用于将整数值映射到字符。键是整数,值是对应的字母。

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;}
};

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com