Loading...
kristiqn.stoikow11 avatar kristiqn.stoikow11 4 Точки

JS Fundamentals - Associative Arrays / More exercises - 01.Garage

Здравейте колеги, въпросът ми е защо следната задача минава с map, а с object не минава на 100% ( 60/100 ) при един и същи код буквално.. ето и линкове - 
obj code с вложен обект= https://pastebin.com/8BE247CF;

obj code с вложен масив = https://pastebin.com/UjfMirjJ;

map code = https://pastebin.com/RgM40GcY;

Доста време отделих, просто за да видя защо не става с обект, но така и не виждам проблема, помагайте..
 Джъдж :

https://judge.softuni.bg/Contests/Practice/Index/1305#0

Условие:

https://softuni.bg/trainings/resources/officedocument/41485/more-exercise-js-fundamentals-may-2019/2343

 

Благодая предварително! 

Тагове:
1
JavaScript Fundamentals 06/10/2019 02:24:51
willystyle avatar willystyle 2472 Точки
Best Answer

Здравей,

според мен грешката е в условието: "...At the end print the result ordered by the
numbers of the garages (no further sorting required)..." Понеже ако това се спази следните две решения с Map и Object би трябвало да минат:

function solveGarageMap(inputArr) {
    let garagesMap = new Map();
    for (let row of inputArr) {
        let [garage, carKeyValues] = row.split(' - ');
        if (!garagesMap.has(garage)) {
            garagesMap.set(garage, [carKeyValues]);
        } else {
            let availableCars = garagesMap.get(garage);
            availableCars.push(carKeyValues);
            garagesMap.set(garage, availableCars);
        }
    }
    let sortedGarages = [...garagesMap.entries()].sort((a, b) => a[0] - b[0]);
    let output = '';
    for (let [currGarage, currCarKeyValue] of sortedGarages) {
        output += `Garage № ${currGarage}\n`;
        for (let currCarProperties of currCarKeyValue) {
            currCarProperties = currCarProperties.replace(/: /g, ' - ');
            output += `--- ${currCarProperties}\n`;
        }
    }
    console.log(output);
}
function solveGarageObject(input) {
    let garages = {};
    for (const line of input) {
        let [garage, carInfo] = line.split(' - ');
        if (!garages.hasOwnProperty(garage)) {
            garages[garage] = [];
        }
        garages[garage].push(carInfo);
    }
    let output = '';
    Object.entries(garages).sort((a, b) => a[0] - b[0]).forEach(([garage, cars]) => {
        output += `Garage № ${garage}\n`;
        for (let currCar of cars) {
            currCar = currCar.replace(/: /g, ' - ');
            output += `--- ${currCar}\n`;
        }
    });
    console.log(output);
}

Обаче и двете решения дават 60%(въпросните 2 теста гърмят), ако от решението с Map, манем сортировката, решението минава 100%. А Map entries връща entries in insertion order (по реда на вкарване), което не е гарантирано при обект (при него не се пази реда на вмъкване). Така че, според мен грешката е в условието, не е при тебе.  Условието е следвало да бъде "...At the end print the result in insertion order of the garages (no further sorting required) ..."

Ако искаш решение, което да не ползва Map, няма да може да ползваш само Object, ще се наложи за да пазиш реда на вкарване, да държиш всичко в масив:

function solveGarageArray(input) {
    let garages = [];
    for (const line of input) {
        let [garageNumber, carInfo] = line.split(' - ');
        let found = garages.find(g => g.garageNumber === garageNumber);
        if (!found) {
            garages.push({
                garageNumber: garageNumber,
                carInfo: []
            });
            found = garages.find(g => g.garageNumber === garageNumber);
        }
        found.carInfo.push(carInfo);
    }
    let output = '';
    garages.forEach(garage => {
        output += `Garage № ${garage.garageNumber}\n`;
        for (let currCar of garage.carInfo) {
            currCar = currCar.replace(/: /g, ' - ');
            output += `--- ${currCar}\n`;
        }
    });
    console.log(output);
}

 

0
06/10/2019 11:55:50
kristiqn.stoikow11 avatar kristiqn.stoikow11 4 Точки

Благодаря! Хем се радвам, че не е в мен проблема, хем кофти, че си бих главата 5-6 часа за грешка.. 😃

Страхотен отговор, както винаги и най-вече полезен! Поздрави! 

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