蓝桥Excel地址 JAVA暴解

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的字母转换
		}
	}

小剧场:仅仅活着是不够的,还需要有阳光,自由和一点花的芬芳。

发布了108 篇原创文章 · 获赞 113 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_43771695/article/details/104569636
今日推荐