Loading...
mfilipov avatar mfilipov 24 Точки

Решение на "Combination"

Друго решение на задачата, но и то е много бавно.

from itertools import product
num = int(input())
counter = 0

for row in product(range(num + 1), repeat=5):
    if int(row[0]) + int(row[1]) + int(row[2]) + int(row[3]) + int(row[4]) == num:
        counter += 1
print(counter)



При n = 25 компютъра ми намира решението за 16 секунди, защото обхожда всички комбинации.
Идеи за по-добро решение.

Тагове:
0
Python 19/11/2018 21:15:05
zhivko1985 avatar zhivko1985 34 Точки

Не пиша на Pyton, но логиката е обща. Можеш да сложиш условна проверка. Когато сборът от предхоните числа надхвърля n, няма смисъл да правиш итерация на следващия цикъл.

Нпр

Ако n = 20 и си стигнал до 10 5 5 защо да въртиш следващите цикли после...

 

 

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