Решение на Първа задача - температура и химични елементи от Иво Яков
Резултати
- 6 точки от тестове
- 0 бонус точки
- 6 точки общо
- 17 успешни тест(а)
- 0 неуспешни тест(а)
Код
Лог от изпълнението
................. Finished in 0.01255 seconds 17 examples, 0 failures
История (3 версии и 6 коментара)
Иво обнови решението на 15.10.2016 01:07 (преди над 8 години)
Това защо е в кода?
М, да, очевидно. Този коментар е излишен :) Харесва ми, че си се сетил да пишеш коментари, но няма смисъл да коментираш очевидни неща. Тук името на константата е достатъчно ясно без да се налага да чета още едно изречение за него :)
Интересно решение с ламбдите :) Тук има възможност за подобрение - помисли как можеш да направиш преобразуванията на 2 стъпки.
В този вариант ако искаш да добавиш нова мерна единица трябва да добавиш 6 функции
Съжалявам, не съм сигурен дали последния ред е празен или не, защото малко не разбирам preview-то в сайта. Принципно трябва да е празен :D и също from_unit + to_unit може да го превърна в символ за да е по-хубаво написан хеша (без ракета и след нея ->), но не съм сигурен кой вариант ще е по-четим (същото и за другите 2 хеша за температурите)
Кода е доста подреден, браво! Също, много е хубаво, че си помислил за коментари, просто някои от тях са доста очевидни от самия код. Аз лично имам следния алгоритъм, когато ми се поиска да коментирам нещо:
- Ако има възможност - променям имената на променливи/константи/функции, така че да описват по-добре кода.
- Ако има възможност - изнасям код в отделна функция или променлива - името й описва кода.
- Мисля как да променя структурата на кода, така че да е по-ясно от кода.
- Ако горните три вече са изпълнени - тогава пиша коментар :)
За празния ред - предполагам говориш за новия ред на края на файла? Той не би трябвало да се вижда като празен ред.
За хеша - ползвай каквото е по-удобно за използване. В случая това е хеш със стрингове за ключове. Иначе ще трябва да викаш .to_sym
Благодаря за feedback-а
Някой от коментарите в случая не са необходими, но съм свикнал да пиша доста коментари, защото съм свикнал да пиша код за хора, които може да не го разбират изобщо.В случая даже ми е трудно да измисля коментарите, защото то просто си е ясно от кода, но аз го пиша все едно е за някой, който няма да схване за какво е тоя хеш или изобщо какво е хеш :D ще ги променя следвайки вашият алгоритъм и ще премахна част от тях за финалната версия.Относно идеята за смятането на две стъпки, замислих се и наистина стигнах до 3 възможни решения, но не съм сигурен кое или дали някое от тях би било по-добро относно четимост на кода и простота на добавяне на нови мерни единици.
Едното е да използвам този вид хеш:
CONVERSION_FORMULAS = {
и да повиквам от метода чрез:
'CK or KC' => ->(x, conv_select) { conv_select == 1 ? x + 273.15 : x - 273.15 },
'CF or FC' => ->(x, conv_select) { conv_select == 1 ? x * 1.8 + 32 : (x - 32) / 1.8 },
'KF or FK' => ->(x, conv_select) { conv_select == 1 ? x * 1.8 - 459.67 : (x + 459.67) * 5.0 / 9 },
}
key=CONVERSION_FORMULAS.keys.find{ |key| key.include? from_unit + to_unit }
Второто е чрез eдин прост case, в който да слагам формулите една след друга
if key.index(from_unit + to_unit) == 0
CONVERSION_FORMULAS[key].call(value, 1)
else
CONVERSION_FORMULAS[key].call(value, 2)
end
case fromUnit+toUnit
when "CK" then 273.15+value
when "CF" then 1.8value+32
when "KC" then value-273.15
when "KF" then value1.8-459.67
when "FC" then (value-32)/1.8
when "FK" then (value+459.67)*5.0/9
else nil
end
А за третото просто мислих, че може превръщанията да станат като верига, например в хеша оставяме само формули за превръщане от C->K, от K->C, от F->K и от K->F и така премахваме директната връзка между фаренхайт и целзии F->C и C->F и просто влизаме в хеша с ключ който е като променливите, които сме избрали за конвертиране, например, за да конвертираме от C към F правим конвертиране от C към K и после от K към F и това цялото се извършва в един цикъл в метода и така би било по-лесно да се добави нова мерна единица Z, защото тогава ще трябва да напишем само 2 формули за връзката и само с последната мерна единица в случая F и винаги за Z ще са само две формули независимо дали сме сложили 100 мерни единици в хеша, обаче, ако имаме много мерни единици и много превръщания това би забавило бързодействието, но пък на една лекция ни казахте да не мислим толкова за бързодействие и за това се сетих и за този метод :D Не съм сигурен до колко това ще направи решението на простата ни задача по-просто, това решение би дало единствено перспектива за разширяване :D
Не съм сигурен дали да остана с този вариант за финалната версия, защото малко не схванах идеята с пресмятането на 2 стъпки и май доста се отклоних в мислите си :D
Интересно решение с ламбдите :) Тук има възможност за подобрение - помисли как можеш да направиш преобразуванията на 2 стъпки.
В този вариант ако искаш да добавиш нова мерна единица трябва да добавиш 6 функции