Общая формула для построения массива чисел из base-n - PullRequest
0 голосов
/ 15 января 2019

Скажем, я хочу построить массив чисел с базой 8 или с базой 26, я не уверен, как подойти к общей формуле для этого:

console.log(arrayOfNumbersOfBase(8, 0, 10));
console.log(arrayOfNumbersOfBase(26, 0, 10));

function arrayOfNumbersOfBase(base, start, size)
{
    var array = [];
  
    for (var i = start, n = size; i < n; i++)
    {
        array.push(i * (base));
    }

    return array;
}

1 Ответ

0 голосов
/ 16 января 2019

Вы можете взять следующий подход в качестве отправной точки, в основном мне пришлось определить несколько служебных методов:

  • mapToChar(n) отображает число n в символьное представление, например, 10 отображается в 'A'.

  • convertToBaseN(n, base) преобразует число n в его представление в данном base. Этот метод использует рекурсивный подход и использует предыдущий.

  • Наконец, generateNumbersOfBase(base, start, size) генерирует массив size элементов, начиная с номера start для заданного base.

КОД:

// Next utility method map a decimal number to a character representation.

const mapToChar = (n) =>
{
    n = (n >= 0 && n <= 9) ? '0'.charCodeAt() + n : n - 10 + 'A'.charCodeAt();
    return String.fromCharCode(n);
}

// Next utility method convert a decimal number to his base-n representation.

const convertToBaseN = (n, base, res = "") =>
{
    if (n <= 0)
       return (res && res.split("").reverse().join("")) || "0";

    // Convert input number to given base by repeatedly 
    // dividing it by base and taking remainder.

    res += mapToChar(n % base);
    return convertToBaseN(Math.floor(n / base), base, res);
}

// Next method generates an array of numbers for a given base.

const generateNumbersOfBase = (base, start, size) =>
{
    return Array(size).fill(0).map((x, idx) => convertToBaseN(start + idx, base));
}

// Finally, generate some arrays.

let base10Array = generateNumbersOfBase(10, 15, 5);
let base2Array = generateNumbersOfBase(2, 5, 9);
let base16Array = generateNumbersOfBase(16, 10, 12);
let base8Array = generateNumbersOfBase(8, 1, 12);

console.log(
    JSON.stringify(base10Array),
    JSON.stringify(base2Array),
    JSON.stringify(base16Array),
    JSON.stringify(base8Array),
);

Теперь, если вам нужно преобразовать некоторое представление base-n обратно в десятичное число, вы можете использовать следующий подход:

const convertToDec = (str, base) =>
{
    let codeA = 'A'.charCodeAt();
    let code0 = '0'.charCodeAt();

    return str.split("").reverse().reduce((acc, c, idx) =>
    {
        let code = c.charCodeAt();
        c = code + ((c >= '0' && c <= '9') ? -code0 : -codeA + 10);
        return acc += c * Math.pow(base, idx);
    }, 0);
}

// Lets convert back some arrays generated on the previous exampel

let base2Array = ["101","110","111","1000","1001","1010","1011","1100","1101"];
let base16Array = ["A","B","C","D","E","F","10","11","12","13","14","15"];

let res2 = base2Array.map(x => convertToDec(x, 2));
let res16 = base16Array.map(x => convertToDec(x, 16));

console.log(
    JSON.stringify(res2),
    JSON.stringify(res16)
);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...