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

力扣刷题-excel表名称序列相转换

1.给你一个字符串 columnTitle ,表示 Excel 表格中的列名称。返回 该列名称对应的列序号 。

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

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

并不是简单的十进制转二十六禁止,因为没有零位,需要考虑

//1.
class Solution {
public:
    int titleToNumber(string columnTitle) {
        int number = 0;
        long multiple = 1;
        for (int i = columnTitle.size() - 1; i >= 0; i--) {
            int k = columnTitle[i] - 'A' + 1;
            number += k * multiple;
            multiple *= 26;
        }
        return number;


    }
};

//2.
class Solution {
public:
    string convertToTitle(int columnNumber) {
        
        string res;
        while(columnNumber>0)
        {
            int i=(columnNumber-1)%26+1;

            res+=i-1+'A';
            columnNumber=(columnNumber-i)/26;//准备处理下一位
        }

        reverse(begin(res),end(res));



        return res;
    }
};
int i=(columnNumber-1)%26+1;
这里先将columnNumber减 1 然后对 26 取余再加 1。这是因为 Excel 列标题的编码方式,从 1 到 26 对应A到Z,但是取余运算%对于 26 的整除情况(如 26、52 等)会得到 0,所以先减 1 保证取余结果在 0 到 25 之间,再加 1 就可以得到 1 到 26 的正确对应值。


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

相关文章:

  • 【Opencv学习】PART1-图像基础处理
  • 安装 Docker(使用国内源)
  • 图形化界面MySQL(MySQL)(超级详细)
  • 使用Go 语言连接并操作 MySQL 数据库
  • 【Python · PyTorch】循环神经网络 RNN(基础概念)
  • 003 STM32基础、架构以及资料介绍——常识
  • MyBatis---代理Dao方式的CRUD、MyBatis参数详解、MyBatis的配置文件
  • Tri Mode Ethernet MAC IP核详解
  • 摆烂仙君传——深度学习秘境奇缘
  • 网络爬虫总结与未来方向
  • maven传递性依赖的原则
  • Photino:通过.NET Core构建跨平台桌面应用程序,.net国产系统
  • C++ 中的模板特化和偏特化
  • R虚拟环境中安装ncdf4库包编译库问题
  • 骑砍2霸主MOD开发(29)-顶点动画
  • # DBeaver 连接hive数仓
  • 标贝科技大模型声音复刻 快速获取高品质专属AI声音
  • 【Rhino】【Python】Create a series of Blocks according to Value of object Property
  • 【042C】基于51RFID门禁系统(LCD12864显示)【Proteus仿真+Keil程序+报告+原理图】
  • Java基础:日期时间相关类
  • python基础导包
  • springmvc-04-Controller及RestFul
  • cocos creator 3.8 3D模型、天空盒、雾 6
  • 基于SpringBoot的京东绿谷旅游信息服务平台设计与实现(源码+定制+开发)
  • 第六届国际科技创新学术交流大会暨新能源科学与电力工程国际学术会议(NESEE 2024)
  • [高阶数据结构三] B-树详解