Loading...

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

debono avatar debono 56 Точки

Задача Pairs by Difference от Arrey - оптимизиране на код.

Колеги, пускам линк към кода ми за решаване на задачата Pairs by Difference от Arreys упражненията.

https://pastebin.com/BpH8GeBk

Тъй като Judge ми дава TimeLimit  на последните два теста, искам да попитам дали кодът може да бъде опримизиран за 100 точки. Знам, че с два foreach цикъла ще мине, но ми е интересно дали може да се пипне нещо, което до ускори изпълнението при големи входове.

 

Поздравиyes 

0
Programming Fundamentals
icowwww avatar icowwww 2673 Точки
Best Answer

Премахни Math.Abs от 23 ред  if (Math.Abs(arr[i] - arr[j]) == difference)

Промени го на  if (arr[i] - arr[j] == difference || arr[j] - arr[i] == difference)

А иначе има грешка в джъдж не би трябвало да ти търси чак толкова от теб. А и като имаме предвид задачата на първа и на втора група в джъдж става малко нечестно едното да има лимит 100 другото 400:

https://image.prntscr.com/image/agdwJgV1SfeMdTS2ma1Hug.jpg

0
10/10/2017 23:34:21
debono avatar debono 56 Точки

Благодаря за коментара!! Не предполагах, че един Math.Abs ти вдига двойно времето за изпълнение. Иначе, да, втора група е дискриминирана, ама така ще вдигнем левъла по-бързоlaugh

0
icowwww avatar icowwww 2673 Точки

xaxa

0
boykopk avatar boykopk 147 Точки

Може да  се премахне едната разлика и пак ще мине.

if (arr[i] - arr[j] == difference)

0
pwnd0rum avatar pwnd0rum 35 Точки

Благодаря, и аз имах проблем с времето, но като махнах Math.Abs тръгна. Макар че пак съм над 100мс, но явно една милисекунда не е проблем :) http://prntscr.com/gwt49w

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