Loading...
StanimirPavlov avatar StanimirPavlov 4 Точки

5. Extract an Non-decreasing Subsequence from an Array - Javascript

Здравейте,

На задача 5. Extract an Non-decreasing Subsequence from an Array не мога да извадя повече от 60/100. Условие: 

Write a JS function that extracts only those numbers that form a non-decreasing subsequence. In other words, you start from the first element and continue to the end of the given array of numbers. Any number which is LESS THAN the current biggest one is ignored, alternatively if it’s equal or higher than the current biggest one you set it as the current biggest one and you continue to the next number.

The input comes as array of strings. Each element will represent a number.

The output is the processed array after the filtration, which should be a non-decreasing subsequence. Each element should be printed on a new line.

Код:https://pastebin.com/LX0BUPqV

Предварително благодаря

Тагове:
1
JavaScript Fundamentals
lorishte avatar lorishte 2 Точки

Малко късно, но ето и моето решение. Даваше ми грешка на един от тестовете, докато разбера, че следващото число може да е по-голямо или равно на предишното.

https://pastebin.com/kjUAdgDK

Някой успя ли да реши задачата с arr.filter(), както е дадено в подсказката на условията?

0
JivkoJelev avatar JivkoJelev 235 Точки

Да и на мен ще ми е много интересно да вида решение с филтър.Доста по-кратък и четим ще е кода.Лошото е че така и не го измислих.

0
RoYaL avatar RoYaL Trainer 6849 Точки

Ще е по-кратък, но няма да е четим. Дайте линк към задачата в Judge. Иначе би трябвало да е нещо такова (по условието от първия пост):

(arr, biggestNumber = -Infinity) => arr.filter(e => ([ret, biggestNumber] = [parseInt(e) >= biggestNumber, Math.max(biggestNumber, e)])[0]).join('\n');

 

3
01/06/2017 16:28:04
lorishte avatar lorishte 2 Точки

Явно става, но наистина не е добре четим.

Ето линк към Judge: https://judge.softuni.bg/Contests/Compete/Index/313#4

Даде 100/100 :)

0
02/06/2017 07:34:27
Bobyto avatar Bobyto 14 Точки
Вариант с филтър, който се чете :)

function arrayFilter(arr) {
    let biggestNum = Number.NEGATIVE_INFINITY;
    function sequense(x) {
        if (biggestNum <= x){
            biggestNum = x;
            return true;
        }else   {
            return false;
        }
    }
    let result = arr.filter(x => sequense(x));
    console.log(result.join('\n'));
}

 

Още един, по-кратък със  spread operator

arr.filter((x, i) => x >= Math.max(...arr.slice(0, i + 1)));

1
26/05/2018 19:12:50
PepiBobanov avatar PepiBobanov 16 Точки

Още един вариант с arr.filter():

function extract(input){
    let max=input[0];
    console.log(input.filter((a) =>a>=max && (max=a)===a).join('\n'));
}
0
Milovanov avatar Milovanov 11 Точки

function nonDecreasingSubsequentNums(arr) {

    let result = [arr.shift()];

    arr.filter(i => i >= result[result.length - 1] ? result.push(i) : '');

    console.log(result.join(' '));

}

 

function nonDecreasingSubsequentNums(arr) {

    let result = [arr.shift()];

    arr.map(i => i >= result[result.length - 1] ? result.push(i) : '');

    console.log(result.join(' '));

}

0
18/04/2020 17:11:19
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.