博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Leetcode] Excel Sheet Column Title Number Conversion Excel列值转换
阅读量:6330 次
发布时间:2019-06-22

本文共 1134 字,大约阅读时间需要 3 分钟。

Excel Sheet Column Number

Related to question Excel Sheet Column Title

Given a column title as appear in an Excel sheet, return its corresponding column number.

For example:

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

26进制

复杂度

时间 O(N) 空间 O(1)

思路

得到数字,其实就是把26进制的数转换为10进制的数。算法就是基本的进制转换方法,从后往前第n位的值乘上26^(n-1)。这里26进制数是1开始的,即A是1。

代码

public class Solution {    public int titleToNumber(String s) {        int num = 0, pow = 1;        for(int i = s.length() - 1; i >= 0 ; i--){            num += (s.charAt(i) - 'A' + 1)*pow;            pow *= 26;        }        return num;    }}

Excel Sheet Column Title

Given a positive integer, return its corresponding column title as appear in an Excel sheet.

For example:

1 -> A2 -> B3 -> C...26 -> Z27 -> AA28 -> AB

26进制

复杂度

时间 O(N) 空间 O(1)

思路

把10进制的转换成26进制,做法是除26取余,一直除到0,最后把余数逆序一下就行了。不过因为A是1,而不是0,相当于26进制的数都整体减1,才能对应上从0开始的十进制数。

代码

public class Solution {    public String convertToTitle(int n) {        StringBuilder sb = new StringBuilder();        while(n != 0){            sb.append((char)('A' + (n - 1) % 26));            n = (n - 1) / 26;        }        return sb.reverse().toString();    }}

转载地址:http://pjboa.baihongyu.com/

你可能感兴趣的文章
为什么要让带宽制约云计算发展
查看>>
[iOS Animation]-CALayer 绘图效率
查看>>
2012-8-5
查看>>
VS中ProjectDir的值以及$(ProjectDir)../的含义
查看>>
我的友情链接
查看>>
PHP实现排序算法
查看>>
Business Contact Mnanager for Outlook2010
查看>>
9种用户体验设计的状态是必须知道的(五)
查看>>
解决WIN7下组播问题
查看>>
陈松松:视频营销成交率低,这三个因素没到位
查看>>
vmware nat模式原理探究,实现虚拟机跨网段管理
查看>>
JavaSE 学习参考:集合运算
查看>>
CSS属性:font-family
查看>>
【Signals and Systems】 SYLLABUS
查看>>
RH135-2-command-line-interface
查看>>
浅谈OS
查看>>
mac下开启docker API远程调用
查看>>
tar 命令的详解
查看>>
Cisco路由器安全配置
查看>>
第十次作业
查看>>