第8题地址:https://fun.coolshell.cn/953172864.html
大概是作进制转换就行,26进制,但是没有从0开始感觉很奇怪(Z相当于0,但是单独一个Z却表示26)。
上代码。
function excel2number(str) {
var sum = 0;
var weight = 1;
for (var i = str.length - 1; i >= 0; --i, weight *= 26) {
sum += (str.charCodeAt(i) - 64) * weight;
}
return sum;
}
var result = excel2number("COOLSHELL") / excel2number("SHELL");
console.log(result);
// 去掉小数
console.log(parseInt(result));
计算结果是小数的,地址404。
去掉小数后,地址:https://fun.coolshell.cn/85165.html
好吧,要的是字符串。
function number2excel(num) {
var result = "";
while (num > 0) {
var r = num % 26;
if (r == 0) {
r = 26;
}
result = String.fromCharCode(r + 64) + result;
num = parseInt(num / 26);
if (r == 26) {
--num;
}
}
return result;
}
console.log(number2excel(85165));
答案是DUYO,得到第9题地址:https://fun.coolshell.cn/DUYO.html
收获:加深了进制间转换的记忆。