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] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 09:08 am (UTC)(link)
но красивей, чем цпп.

кстате, почему «был»-то? у меня до сих пор есть. и у яблок тоже. %-)

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

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 09:25 am (UTC)(link)
эх. я бы тоже удрал, но… наоборот — тянут в цэпэпэ. если бы не Qt — уже давно повешался бы.

ну, и — эффективность же. хотя я втихаря встраиваю в свои софты самописный минилисп (да-да, с нормальной поддержкой tail calls, без переполнения стека! %-), и кучу логики делаю на нём. хороший, годный лисп — быстрее tinySCHEME, хоть и без байт-кода! %-)

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

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 11:04 am (UTC)(link)
гыгыгы. в бытность мою в госконторе я «пошутил», типа. мой софт был на Delphi, но. там была:
а) встроеная отладочная консоль а-ля квака;
б) 99% логики и все отчёты делались на самописном лиспе (тогда ещё весьма кривом, но); на Delphi было только ядро и биндинги; ну, и лисп. %-)

что, сука, характерно (ц) — когда я уволился, на весь мой софт наняли негров — переписывать. потому что никто ниасилил лисп. а винт мой форматнули, потому что ниасилили венды, где нет explorer'а (у меня blackbox стоял %-). зря форматнули — там в единственном экземпляре были исходники.

жаль, что я исходники не забрал тогда.

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

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 12:13 pm (UTC)(link)
REXX? REXX, да?! REXX НЯЯЯАААА! (фанат полуоси во мне прыгаяет и някает)

[identity profile] afa-at-work.livejournal.com 2009-07-20 01:51 pm (UTC)(link)
хехе
в войне бобик традиционно запинал всех конкурентов, ага.
велкам ту ru.os.cmp

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 09:29 pm (UTC)(link)
не, там flamewar.

[identity profile] afa-at-work.livejournal.com 2009-07-21 07:11 am (UTC)(link)
[пытаясь сообразить, как называются холивары с весенне-осенними обострениями]

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 09:26 am (UTC)(link)
и меньше tinySCHEME, кстате!

да, это пеар. %-)