0

可能重复:
将数字转换为可能的最短字符串,同时保持唯一性

我想计算一些东西,我只有一个数字来报告结果,所以我想用字母表示 > 9 的数字。例如

1 => 1
5 => 5
10 => A
30 => U
55 => u   // I may have an off-by-one error here -- you get the idea
>61 => z  // 60 will be more than enough, so I'll use z to mean "at least 62"

使用 javascript 最简单的方法是什么?

4

3 回答 3

0

这是执行此操作的众多方法之一:

function num2letter(num) {
    if( num > 61) return "z";
    if( num < 0) return num;
    return "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"[num];
}
于 2012-06-26T21:01:35.203 回答
0

我认为 base 36 就足够了:

function oneDigit(n) {
    var BASE=36;
    if (n >= BASE-1) { n = BASE-1; }
    return n.toString(BASE);
}
于 2012-06-26T21:10:10.743 回答
0

另一种方法:

function parse(x)
{
    if(x<10)return x;
    else if(x<36)return String.fromCharCode(x+55).toUpperCase();
    else if(x<62)return String.fromCharCode(x+29).toLowerCase();
    else return "z";
}

还有这个小测试:

var res="";
for(var a=-10;a<70;a++)res+=a+" -> "+parse(a)+"\n";
alert(res);

还有一个小提琴:http: //jsfiddle.net/nD59z/4/

同样的方式,但字符较少且难以理解:

function parse(x)
{
    return x<10?x:(x<36?String.fromCharCode(x+55).toUpperCase():(x<62?String.fromCharCode(x+29).toLowerCase():"z"));
}
于 2012-06-26T21:20:43.977 回答