171.Excel表列序号

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

例如,

1
2
3
4
5
6
7
8
A -> 1
B -> 2
C -> 3
...
Z -> 26
AA -> 27
AB -> 28
...

示例 1:

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

Solution

先将字符串转换为数组,然后计算sum,从最高位开始,按照其他进制转10进制的方法,值=26的n次方×本身字符的值

1
2
3
4
5
6
7
8
9
10
class Solution {
public int titleToNumber(String columnTitle) {
char []a=columnTitle.toCharArray();
int sum=0;
for(int i=0;i<a.length;i++){
sum+=(a[i]-'A'+1)*Math.pow(26,a.length-1-i);
}
return sum;
}
}