Loading...

Във форума е въведено ограничение, което позволява на потребителите единствено да разглеждат публикуваните въпроси.

BorislavNikolov99 avatar BorislavNikolov99 3 Точки

Problem 8. Balanced Parentheses

Problem 8. Balanced Parentheses   

https://softuni.bg/trainings/resources/officedocument/37032/exercise-problem-descriptions-csharp-advanced-january-2019/2243 

Колеги имам проблем с тази задача от C# Advanced дава 75/100 а идея си нямам защо някой може ли да помогне 

https://pastebin.com/AfcGGbvd

Тагове:
0
C# Advanced
MartinBG avatar MartinBG 4803 Точки

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

Ето едно примерно решение на Java, което използва този алгоритъм - ако ти хареса като идея, лесно може да го "преведеш" и на C#.

1
20/01/2019 01:19:21
Galin.P87 avatar Galin.P87 44 Точки

BorislavNikolov99, алгоритъма ти не отчита случаи тип ()[], които също са валиден случай. Затова ти бягат последните 25 точки.

1
20/01/2019 20:15:35
Joro_Paspalev avatar Joro_Paspalev 23 Точки

Здравейте, 

и аз като BorislavNikolov99 първоначално реших да разделя входните данни на половина в Stack и Queue, но както правилно колегата Galin.P87 пише и това ()[] е валиден вход. Затова метода с разделянето не ни върши работа. Ето и моето променено решение, което дава 100/100 - https://pastebin.com/3YEuyzNg

Поздрави!

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