Название: Искусство программирования (задача 7) Отправлено: Alder от Сентябрь 24, 2008, 06:04:06 Разомнем немного мозги :)
Дана таблица вида: Код: | a | b | c | В ячейках произвольно расставлены галочки, минимум одна галочка в строке, например Код: | a | b | c | Нужно вычислить все варианты различных комбинаций галочек от первой до последней строки(a, b и c). То есть для примера выше ответ такой: Два варианта. Вариант 1: bacaa Вариант 2: bccaa Побеждает минимальная по объему программа. Языки реализации - любые (у меня есть ответ на Ruby, он меня поразил своей краткостью) Название: Re: Искусство программирования (задача 7) Отправлено: Sochin от Сентябрь 25, 2008, 06:42:40 Код: (C# 3.0) static class Program Название: Re: Искусство программирования (задача 7) Отправлено: Alder от Сентябрь 26, 2008, 12:48:02 А кроме Сочина больше никому не интересно?
Название: Re: Искусство программирования (задача 7) Отправлено: LazarusLong от Сентябрь 26, 2008, 08:00:48 А кроме Сочина больше никому не интересно? Я не совсем врублюсь в условие, а так бы поучаствовал.Название: Re: Искусство программирования (задача 7) Отправлено: Sochin от Октябрь 15, 2008, 04:00:59 Код: ("F#") #light Цитировать ["BAСAA"; "BССAA"] Алдер, давай свой вариант. =) Название: Re: Искусство программирования (задача 7) Отправлено: Alder от Октябрь 15, 2008, 04:07:40 Код: ("Ruby") # Produces list of permutations of elements according to a set of rules. Думаю, что код Сочина на F# будет самым коротким :) Название: Re: Искусство программирования (задача 7) Отправлено: Storm от Октябрь 21, 2008, 12:25:15 F# не знаю, ничего не скажу, но, ИМХО, подобного плана задачи следует решать с применением лишь условного ветвления и цикла с заданным количеством итераций, как учил Дейкстра, иначе это все будет сведено к мерянью языками программирования.
можно написать модуль для Perl с реализацией поставленной задачи и программа будет сведена к вызову функции с возвратом ссылки на список. да и задачу уточнить не помешает, потому что не въехал какие варианты на выходе должны быть. Название: Re: Искусство программирования (задача 7) Отправлено: Sochin от Октябрь 21, 2008, 01:43:53 F# не знаю, ничего не скажу, но, ИМХО, подобного плана задачи следует решать с применением лишь условного ветвления и цикла с заданным количеством итераций, как учил Дейкстра, иначе это все будет сведено к мерянью языками программирования. Мир не замкнут на одних лишь императивных языках. Так что если и мерянье, то скорее парадигмами. =) |