Преобразование десятичных знаков в sexagesimal (base sixty) в javascript

Каков наилучший способ преобразования десятичных чисел (базовая десятка) в sexagesimal (base sixty), представленный в виде строки с использованием цифр 0-9, A-Z и a-x в качестве цифр.

Я планирую закодировать его в 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;
    }
}();

Ответ 1

Это работает с предоставленными тестовыми данными, но вы, вероятно, захотите провести еще несколько тестов:

<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>

Ответ 2

Просто повторно разделите его на 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)

Ответ 3

Начните с разбиения числа на целую и дробную часть.

Для целочисленной части возьмите модуль, чтобы вытащить наименее значимую цифру, затем разделите на 60 и повторите.

Для дробной части многократно умножьте на 60 и возьмите целую часть, чтобы получить цифры результата. Если вы когда-нибудь закончите с нулем, что маловероятно, вы закончите. Скорее всего, вы захотите прекратить работу после того, как вы извлечете определенное количество цифр.

Ответ 4

Для чего стоит, здесь модификация решения для преобразования в любую базу до 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/