psilogic: (Default)
psilogic ([personal profile] psilogic) wrote2009-07-19 06:21 pm

Зодачка

Специально для любителей шОблоноф и прочих C++ наворотов. :) Сразу пердупердяю: задачка с подвохом.

Дано.

В программе есть некоторое количество классов, которые являются элементами односвязных списков с internal storage (проще говоря, это когда указатель на следующий элемент является членом класса).

Классы имеют вид:
class MyClass...
{
   MyClass *nextListItem;


Причем, варьируется не только название класса, но и название поля "nextListItem".

Задача.

Написать универсальную функцию вставки в начало списка с применением template, inline и pointer-to-member операторов. На входе должны быть: вставляемый элемент; указатель на первый элемент; название поля, указывающего на следующий элемент и тип класса. Функция может быть глобальной или членом namespace или функцией какого-либо нового класса - важно, чтобы она была одна, но работала для всех тех классов. Функция должна работать примерно так же, как ниже представленный #define:

#define INSERT_TO_LIST(firstItemPtr, item, nextItemName) \
(item)->nextItemName= (firstItemPtr), (firstItemPtr)= (item)


Посчитать количество строк в полученной функции. Факультативно: перечислить и обосновать преимущества перед приведенным #define.

[identity profile] afa-at-work.livejournal.com 2009-07-20 10:44 am (UTC)(link)
я по очень забавным граблям прост плясал. еще в бытность пополамного 2.95. более забавные - лишь в борландЪ цЭ 4.5 фо пополаму, да. когда включая оптимизацию - компилер во вложенном цикле делал push i; push j; pop i; pop j; - и счетчики цикла менялись местами.
потому и люблю ваткомку - шо хоть какой контроль существовал. и скорость была весьма на уровне.

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 10:50 am (UTC)(link)
борланд цэ надо убивать-убивать-убивать, конечно. всед за ним валить m$vc, который до сих пор, блядь, C99 не понимает. а гнусь хвалить-хвалить за наличие вложеных функций. которые — гыгы — можно передавать как callbacks. почти ламбды. %-)

[identity profile] afa-at-work.livejournal.com 2009-07-20 10:52 am (UTC)(link)
скромненько напоминает про шарпы, и, пока толпа занята убивайством - удирает мочить рельсы

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:00 am (UTC)(link)
(расчехляет BFG) ЧОЧОЧО?

(закукливается в iddqd)

[identity profile] afa-at-work.livejournal.com 2009-07-20 11:37 am (UTC)(link)
ххе!
свысока смотрит на сквик: хоть п гуйню присобачили шоль вместо доснавигаторской попугаистости!

Re: (закукливается в iddqd)

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:51 am (UTC)(link)
ну, а чо, чо есть лучше сквика? не, у меня, конечно, есть свой смолтолк, без шлх и блэкджека, но именно как среду — что лучше-то?

Re: (закукливается в iddqd)

[identity profile] afa-at-work.livejournal.com 2009-07-20 11:59 am (UTC)(link)
а со времен васта и цинкомы ничего нет.
и если п попугаистость отрывалась без хлопот - я п пользовался. но слишком много телодвижений и слишком далекий уполз от строгости стандартных контролов, для которых мыша не обязательна

Re: (закукливается в iddqd)

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 12:09 pm (UTC)(link)
ну так опять же — а выбора особого нет. только разве сесть и написать самому.

Re: (закукливается в iddqd)

[identity profile] afa-at-work.livejournal.com 2009-07-20 12:23 pm (UTC)(link)
ну примерно для минимизации телодвижений на руби и уполз. гст рядышком валяется и мелочевку всё-равно какую т ковыряю, но уже не так, да

Re: (закукливается в iddqd)

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 12:26 pm (UTC)(link)
рубя тоооооормаз!

Re: (закукливается в iddqd)

[identity profile] afa-at-work.livejournal.com 2009-07-20 12:36 pm (UTC)(link)
гг
оптимизировать надо алгоритмически!
и тормозить не будетЬ

[identity profile] psilogic.livejournal.com 2009-07-20 10:54 am (UTC)(link)
[ а гнусь хвалить-хвалить за наличие вложеных функций. которые — гыгы — можно передавать как callbacks. почти ламбды. ]

тогда жабу хвалить-хвалить, у нее подобная ж херня :))

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 10:59 am (UTC)(link)
у жабы дерьмовая VM. это раз.

два: я НЕ ПОНИМАЮ, почему при наличии VM с GC в языке нет средств для нормальных лямбд. не понимаю. (ненене, я опять в курсе про scala и про лиспы для jvm %-).

[identity profile] psilogic.livejournal.com 2009-07-20 11:01 am (UTC)(link)
извини, в лямбдах я не секу - это что-то сакральное или просто представление всего подряд списками?

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:10 am (UTC)(link)
не, ничего сакрального. в очень грубом описании — анонимные функции, которые объявляются и тут же вызываются. и могут рекурсивно звать сами себя. google «scheme», «lambda calculus».

в лиспе (настоящем, гыгы %-) вообще ВСЕ функции — лямбды. просто лямбду можно присвоить переменной (потому что функция там — first class citizen).

кстати, в любимом ecma-script это есть. жаль, что почти все, кто говорят, что «знают javascript» — на самом деле нихуя его не знают. он почти лисп, если поглубже выучить. потому риспект и уважуха троллям за QtScript. нириспект и ниуважуха за то, что его использование так прикрыто лицензией, что он становится бессмысленным.

[identity profile] psilogic.livejournal.com 2009-07-20 11:21 am (UTC)(link)
ссылку съел, четаю, просвещаюсь
похоже на то как в цермело-френкеле все выражается через упорядоченные пары

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:30 am (UTC)(link)
ну, немерле — это матан. такой же, как хацкель, тащемта.

[identity profile] psilogic.livejournal.com 2009-07-20 11:36 am (UTC)(link)
это не матан, это теория множеств - матлогика. чёрч изъебнулся :)

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:52 am (UTC)(link)
всё это матан. а кто не знает матан, тот будет переработан в метан! %-)

[identity profile] psilogic.livejournal.com 2009-07-20 11:54 am (UTC)(link)
матан - это матанализ, к нему относят обычно дифференциальное и интегральное исчисление а также теорию пределов. а лямбды, судя по всему, - из другой оперы - теория множеств и т.п...

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:56 am (UTC)(link)
ой, да знаю я, знаю… не будь занудным, /b/ратья осуждают! %-)

[identity profile] psilogic.livejournal.com 2009-07-20 11:59 am (UTC)(link)
ну мне же тоже хочеца иногда выложить на стол хвост... =))

(no subject)

[identity profile] psilogic.livejournal.com - 2009-07-20 12:16 (UTC) - Expand

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:58 am (UTC)(link)
кстате, очень не хватает в цэ closures и continuations.

[identity profile] psilogic.livejournal.com 2009-07-20 12:01 pm (UTC)(link)
а это что за звери? может есть что-то подобное, ты только объясни о чем речь. у меня с терминологией всегда напряги...

(no subject)

[identity profile] psilogic.livejournal.com - 2009-07-20 12:22 (UTC) - Expand

(no subject)

[identity profile] psilogic.livejournal.com - 2009-07-20 12:37 (UTC) - Expand

[identity profile] eugenius-nsk.livejournal.com 2009-07-21 03:03 am (UTC)(link)
> кстати, в любимом ecma-script это есть
А ещё у него прототипная объектная модель, да :-)