Професионална програма
Loading...
+ Нов въпрос
enevlogiev avatar enevlogiev 1167 Точки

[Advanced C#] Бонус алгоритмични упражнения

Колеги,

Събрал съм в един файл алгоритмични задачи, които нито са особено сложни, нито крайно елементарни. Целта е да се решат по възможно най-прост начин, без използване на вградени методи, библиотеки или т.н. техники, които биха свели алгоритъма до един ред.

Задачите не са задължителни, няма да влияят негативно или положително върху оценките ви. Единствената цел е да развият алгоритмично мислене. Намират се тук - секция Подготовка за изпит.

Който има време - да се захваща.

 

14
C# Advanced
djc_bg2015 avatar djc_bg2015 922 Точки

Много ти благодаря за задачките, тъкмо се чудех как да прекарам следобеда :)

Ето ги моите решения, надявам се да съм спазил условието "да се решат по възможно най-прост начин".

https://github.com/vdonchev/AlgorithmicThinking

ПС. тествал съм ги с примерните входни данни, но не претендирам, че работят 100% коректно. Ако някой има желание и време да ги прегледа, нека пише.

 

Поздрави!

3
29/09/2015 20:06:42
enevlogiev avatar enevlogiev 1167 Точки

Добра работа : )

Виждам, че си упражнил регексите wink Оригинално решение на калкулатора, вместо стек и опашки ползваш само лист. Браво, много ми беше любопитно да го разгледам.

На някои места може да съкратиш. В четвърта задача метода ConvertToInt(char ch) се свежда до:

return ch - '0';

Първа задача - масивът може да се обърне in-place, така необходимата памет пада двойно

for (index = 0; index < length / 2; index++)
    swap(arr[index], arr[length - 1 - index]);

 

4
djc_bg2015 avatar djc_bg2015 922 Точки

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

ch - '0' -> yes, изобщо не ми мина през ума ... :)

Утре, ще добавя оптимизациите, а ако има още подобни задачки, ще се радвам пак да ги споделиш с нас.

Поздрави!

 

0