Excel单元格的地址表示很有趣,它使用字母来表示列号。
比如,
A表示第1列,
B表示第2列,
Z表示第26列,
AA表示第27列,
AB表示第28列,
BA表示第53列,
…
当然Excel的最大列号是有限度的,所以转换起来不难。
如果我们想把这种表示法一般化,
可以把很大的数字转换为很长的字母序列呢?
本题目既是要求对输入的数字, 输出其对应的Excel地址表示方式。
例如,
输入:
26
则程序应该输出:
Z
思路:这种问题,还是得要一个进制转换,用一个数组存放它每次的值,最后倒序转换输出就可…
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int[] arr = new int[1000]; //存放数值
int n = scanner.nextInt();
int i = 1; //字母是1-26,就从1开始
while (n != 0) { //输入的数字不等于0才可进入循环
if (n % 26 == 0) { //输入数字%26==0
arr[i] = 26 + 64; //存到数组里,加数字转换一下(为啥加64)别忘记刚开始咱们给的初始值是1哦
n -= 1; //把用过的Z抹掉!!(这个是重点)
} else {
arr[i] = n % 26 + 64; //余几加64就能转换多出来的字母
}
n /= 26; //一个整数/26,一个字母一个字母的取
i++;
}
for (int j = i - 1; j > n; j--) { //同上道理,倒序输出就可
System.out.print((char) arr[j]);//别忘记char的字母转换
}
}