在千亿级转换程序基础上,10的52次方级别的转换程序诞生了,不过由于计算机数据长度原因,输入改为十进制字符串。虽然一般情况下都用不着,还是尝试了一下。
function cunit (i) {//计算单位
if (i % 4 == 3) return 24 - (i - 3) / 4;
else return 12 - i % 4;
}
function ch_num (n) {
var i, j, k, num = new Array (52).fill (0);
var ch = new Array (104).fill (0);
k = 0;
if (n.length == 0 || n.length > 52) {//范围限制
return {k, ch};
}
if (n.length == 1) {//0到9
ch [k++] = n[0] / 1;
return {k, ch};
}
if (n.length == 2 && n[0] == 1) {//10到19
if (n[1] == 0) {
ch [k++] = 10;
return {k, ch};
} else {
ch [k++] = 10;
ch [k++] = n[1] / 1;
return {k, ch};
}
}
for (i = 0; i < n.length; i++) {//右对齐
num [51 - i] = n[n.length - 1 - i] / 1;
}
for (i = 52 - n.length; i < 52; i++) {//遍历
if (num [i] == 0) {//遇到0
for (j = i; j < 52; j++) {//循环处理0
if (num [j] == 0) {
if (j < 48 && j % 4 == 3 && j - i < 3) ch [k++] = cunit (j);
if (j == 51) i = 51;//直到末尾还是0,结束
} else {//遇到数字,前补零,后补单位,结束循环处理0
ch [k++] = 0;
ch [k++] = num [j];
if (j < 51) ch [k++] = cunit (j);//个位不加单位
i = j;
break;
}
}
} else {//遇到数字,补单位
ch [k++] = num [i];
if (i < 51) ch [k++] = cunit (i);//个位不加单位
}
}
return {k, ch};
}
function obj2str ({k, ch}) {
var i, str = '';
var tab = [ '零', '一', '二', '三', '四', '五', '六', '七', '八', '九', '十', '百', '千', '万', '亿', '兆', '京', '垓', '秭', '穣', '沟', '涧', '正', '载', '极' ];
if (k == 0) return str;
for (i = 0; i < k; i++) {
str += tab [ch [i]];
}
return str;
}
obj2str (ch_num ('9999999999999999999999999999999999999999999999999999'));
输出结果:
'九千九百九十九极九千九百九十九载九千九百九十九正九千九百九十九涧九千九百九十九沟九千九百九十九穣九千九百九十九秭九千九百九十九垓九千九百九十九京九千九百九十九兆九千九百九十九亿九千九百九十九万九千九百九十九'