Преобразование десятичных знаков в шестнадцатеричное (основание шестьдесят) в JavaScript
Каков наилучший способ преобразовать десятичные числа (основание десять) в шестнадцатеричное (основание шестьдесят), представленное в виде строки, используя цифры 0-9, AZ и топор в качестве цифр.
Я планирую закодировать его в javascript, но любая помощь приветствуется.
Пример использования:
>>decToSex(60);
"10"
>>decToSex(123);
"23"
>>decToSex(1000000);
"4bke"
>>decToSex(1234567.89);
"5gu7.rO"
Последний код, который я использовал, основан на ответе Паоло:
var decToSex = function(){
var decToSexMap = ['0','1','2','3','4','5','6','7','8','9',
'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z',
'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x'];
return function(number){
var negative = '';
if (number < 0){
var negative = '-';
}
number = number.toString().split('.');
var integer = Math.abs(number[0]);
var fraction = number[1];
var result = '';
do {
result = decToSexMap[integer % 60] + result;
integer = parseInt(integer / 60);
} while (integer > 0);
if (fraction){
var decimalPlaces = fraction.toString().length;
result += '.';
fraction = parseFloat('.' + fraction);
var x = 0;
do {
x++;
var res = (fraction * 60).toString().split('.');
result = result + decToSexMap[res[0]];
if (res[1]) {
fraction = parseFloat('.' + res[1]);
}
else {
break;
}
} while (x < decimalPlaces);
}
return negative + result;
}
}();
4 ответа
Это работает с предоставленными тестовыми данными, но вы, вероятно, хотите выполнить еще несколько тестов:
<script>
var convert = new Array(0,1,2,3,4,5,6,7,8,9,'A','B','C','D','E','F','G','H','I','J','K',
'L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','a',
'b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q',
'r','s','t','u','v','w','x');
function decToSex(num) {
var extract = num.toString().split('.');
num = extract[0];
var pieces = new Array();
do {
pieces.push(convert[num % 60]);
num = parseInt(num/60);
} while (num > 0);
pieces = pieces.reverse();
var rem = extract[1];
if(rem) {
rem = parseFloat('.' + rem);
var x = 0;
var dec = new Array();
do {
x++;
var res = (rem * 60).toString().split('.');
dec.push(convert[res[0]]);
if(res[1]) {
rem = parseFloat('.' + res[1]);
} else {
break;
}
} while (x < 3); // work up to 3 decimal places, change for more.
}
var myResult = pieces.join('');
if(dec) {
myResult += '.' + dec.join('');
}
return myResult;
}
alert(decToSex(60));
alert(decToSex(123));
alert(decToSex(1000000));
alert(decToSex(1234567.89));
</script>
Для чего стоит, вот модификация решения для преобразования в любую базу до 64:
// Convert decimal into a base between 2 and 64
var decToBase = function() {
var decToBaseMap = [
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z',
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'Y', 'Z',
'+', '/'];
return function(number, base) {
if (base < 2 || base > 64) {
return "#base should be between 2 and 64#";
}
var negative = '';
if (number < 0) {
negative = '-';
}
number = number.toString().split('.');
var integer = Math.abs(number[0]);
var fraction = number[1];
var result = '';
do {
result = decToBaseMap[integer % base] + result;
integer = parseInt(integer / base, 10);
} while (integer > 0);
if (fraction) {
var decimalPlaces = fraction.toString().length;
result += '.';
fraction = parseFloat('.' + fraction);
var x = 0;
do {
x++;
var res = (fraction * base).toString().split('.');
result = result + decToBaseMap[res[0]];
if (res[1]) {
fraction = parseFloat('.' + res[1]);
}
else {
break;
}
} while (x < decimalPlaces);
}
return negative + result;
};
}();
alert(decToBase(2011, 64)); // displays "VR"
Вы можете поиграть с этим здесь: http://jsfiddle.net/kaicarver/d3Zn2/
Начните с разбиения числа на целую и дробную часть.
Для целочисленной части возьмите модуль, чтобы извлечь наименее значимую цифру, затем разделите на 60 и повторите.
Для дробной части многократно умножьте на 60 и возьмите целочисленную часть, чтобы получить результирующие цифры. Если вы когда-нибудь получите ноль, что маловероятно, вы закончили. Скорее всего, вы захотите прекратить после того, как вы извлечете определенное количество цифр.
Просто несколько раз делите его на 60, пока не останетесь с нулем. Каждый раз возьмите модуль и преобразуйте его в соответствующий символ и добавьте его в выходную строку.
Изменить: для десятичных, скажем, вы ищете до 3 60 десятичных знаков:
Начните с 0,98765 (база 10)
0.98765 * 60 -> 59.259 -> first post-decimal character is 59 converted to its 60decimal character, then carry the .259
.259 * 60 -> 15.54 -> second char is 15 converted to its 60decimal character, then carry the .54
.54 * 60 -> 32.4 -> round it this time (its the last char) -> last char is 32 as its 60dec char
Таким образом, 0,98765 (основание 10) становится 0.[59] [15] [32] (база 60)