Excel表列序号

题意:

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

例如:

A -> 1

B -> 2

C -> 3

...

Z -> 26

AA -> 27

AB -> 28

...

示例 1:

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

示例 2:

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

示例 3:

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

提示:

  • 1 <= columnTitle.length <= 7
  • columnTitle 仅由大写英文组成
  • columnTitle 在范围 ["A", "FXSHRXW"]

题目来源: https://leetcode.cn/problems/excel-sheet-column-number/description/

解题方法:

解题思路

  • 标签:字符串遍历,进制转换
  • 初始化结果 ans = 0,遍历时将每个字母与 A 做减法,因为 A 表示 1,所以减法后需要每个数加1,计算其代表的数值 num = 字母 - 'A' + 1
  • 因为有 26 个字母,所以相当于 26 进制,每 26 个数则向前进一位
  • 所以每遍历一位则ans = ans * 26 + num
  • ZY 为例,Z 的值为 26Y 的值为 25,则结果为 26 * 26 + 25=701
  • 时间复杂度:O(n)



代码:

php 复制代码
function titleToNumber($columnTitle) {
    $ans = 0;
    for($i=0; $i < strlen($columnTitle); $i++) {
        $num = ord($columnTitle[$i]) - ord('A') + 1;
        $ans = $ans * 26 + $num;
    }
    return $ans;
}
php 复制代码
function titleToNumber($columnTitle) {
    $num = 0;
    $strlen = strlen($columnTitle);
    for($i = 0; $i < $strlen; $i++){
        $column_no = ord($columnTitle[$i]) - 64;
        $num += 26 ** ($strlen - $i - 1) * $column_no;
    }
    return $num;
}

参考:

作者:画手大鹏

链接:https://leetcode.cn/problems/excel-sheet-column-number/solutions/6849/hua-jie-suan-fa-171-excelbiao-lie-xu-hao-by-guanpe/

相关推荐
爱尔兰极光7 小时前
LeetCode 热题 100--字母异位词分组
算法·leetcode·职场和发展
darkb1rd7 小时前
三、PHP字符串处理与编码安全
android·安全·php
EnglishJun7 小时前
数据结构的学习(三)---双向链表与循环链表
数据结构·学习·链表
梵刹古音7 小时前
【C语言】 数组基础与地址运算
c语言·开发语言·算法
im_AMBER7 小时前
Leetcode 112 两数相加 II
笔记·学习·算法·leetcode
long3167 小时前
KMP模式搜索算法
数据库·算法
_OP_CHEN7 小时前
【算法基础篇】(五十三)隔板法指南:从 “分球入盒” 到不定方程,组合计数的万能解题模板
算法·蓝桥杯·c/c++·组合数学·隔板法·acm/icpc
近津薪荼7 小时前
优选算法——滑动窗口3(子数组)
c++·学习·算法
遨游xyz7 小时前
数据结构-栈
java·数据结构·算法
ghie90907 小时前
基于动态规划算法的混合动力汽车能量管理建模与计算
算法·汽车·动态规划