Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Как округлить число? (https://javascript.ru/forum/dom-window/79505-kak-okruglit-chislo.html)

s24344 17.02.2020 18:31

Как округлить число?
 
Всем привет. Ребята, подскажите, как решить задачу.
У меня, к примеру, есть массив цифр:
const arrayNumbers = [-5, 0, 5, 10, 15, 20, 25, 30, 35]
const n = 23.45
const res = null

Моя задача в следующем, 23.45, ближе всего к числу 25 (из массива), в переменную res мне необходимо записать именно это число 25.
Если придет, например, 11,38, то в переменную res нужно записать число 10 (число из массива).

Nexus 17.02.2020 19:44

(() => {
    const arrayNumbers = [-5, 0, 5, 10, 15, 20, 25, 30, 35];
    const n = 23.45
    const res = arrayNumbers[arrayNumbers.reduce(function (res, value, index) {
        return (value = Math.abs(n - value)) < res.value ? {index, value} : res;
    }, {index: null, value: Infinity}).index];

    alert(res);
})();


upd.
(() => {
    const n = prompt('Enter the number', 11.38) || 23.45;
    const arrayNumbers = [-5, 0, 5, 10, 15, 20, 25, 30, 35];
    const res = arrayNumbers[arrayNumbers.reduce(function (res, distance, index) {
        return (distance = Math.abs(n - distance)) < res.distance ? {index, distance} : res;
    }, {index: 0, distance: Infinity}).index];

    alert(`n = ${n}; res = ${res}`);
})();

рони 17.02.2020 20:38

массив поиск ближайшего
 
s24344,
:)
const arrayNumbers = [-5, 0, 5, 10, 15, 20, 25, 30, 35];
const n = 23.45;
const k = 11.38;
const res = (a, b, c) => (b = a.map(a => Math.abs(a - b)), c = Math.min(...b), b = b.findIndex(a => a === c), a[b]);
const fn = res.bind("",arrayNumbers);
alert(JSON.stringify([n, k].map(fn)));

рони 17.02.2020 20:59

s24344,
https://javascript.ru/forum/events/7...tml#post481478

Alexandroppolus 18.02.2020 00:04

ежели массив отсортированный, и при этом большой, то лучше бинарный поиск

function binSearch(arr, x) {
    if (!arr || !arr.length || arr[arr.length - 1] < x) return arr ? arr.length : 0;
    var b = 0, e = arr.length;
    while (e > b) {
        var idx = Math.floor((b + e) / 2);
        if (arr[idx] < x) b = idx + 1;
        else e = idx;
    }
    return e;
}

function round(n, nums) {
    var pos = binSearch(nums, n);
    if (pos === nums.length) return nums[nums.length - 1];
    if (pos === 0) return nums[0];
    return n - nums[pos - 1] < nums[pos] - n ? nums[pos - 1] : nums[pos];
}

// -----------------
var arrayNumbers = [-5, 0, 5, 10, 15, 20, 25, 30, 35];

alert([-7, 6, 11, 28, 60].map(v => v + ' -> ' + round(v, arrayNumbers)).join('\n'))

Nexus 18.02.2020 14:03

рони, не срача ради, а интереса для
Зачем писать трудночитаемый код, как в посте №3?
Я про функцию в одну строку, разумеется.

рони 18.02.2020 15:07

Цитата:

Сообщение от Nexus
трудночитаемый

:-?
const arrayNumbers = [-5, 0, 5, 10, 15, 20, 25, 30, 35];
const n = 23.45;
const k = 11.38;
/*const res = (a, b, c) => (b = a.map(a => Math.abs(a - b)), c = Math.min(...b), b = b.findIndex(a => a === c), a[b]);*/
const search = (array, number) => {
   const arrayAbs = array.map(value => Math.abs(value - number));
   const minArrayAbs = Math.min(...arrayAbs);
   const indexMinArrayAbs = arrayAbs.findIndex(value => value === minArrayAbs);
   return array[indexMinArrayAbs]
}
/*const fn = res.bind("",arrayNumbers);*/
const fn = search.bind("",arrayNumbers);
alert(JSON.stringify([n, k].map(fn)));

Nexus 18.02.2020 17:42

рони, это не тот ответ, к сожалению, на который я рассчитывал.
"Развернуть" код я и сам мог, вопрос в том, почему его не сразу писать таким, как в посте №7?

Можете проигнорировать вопрос.

рони 18.02.2020 18:00

Цитата:

Сообщение от Nexus
почему его не сразу писать таким

код утратил лаконичность, в этом и была задумка, плюс показать, что есть альтернатива методу reduce

Nexus 21.02.2020 12:53

рони, спасибо.


Часовой пояс GMT +3, время: 05:51.