![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
Специально для любителей шОблоноф и прочих C++ наворотов. :) Сразу пердупердяю: задачка с подвохом.
Дано.
В программе есть некоторое количество классов, которые являются элементами односвязных списков с internal storage (проще говоря, это когда указатель на следующий элемент является членом класса).
Классы имеют вид:
Причем, варьируется не только название класса, но и название поля "nextListItem".
Задача.
Написать универсальную функцию вставки в начало списка с применением template, inline и pointer-to-member операторов. На входе должны быть: вставляемый элемент; указатель на первый элемент; название поля, указывающего на следующий элемент и тип класса. Функция может быть глобальной или членом namespace или функцией какого-либо нового класса - важно, чтобы она была одна, но работала для всех тех классов. Функция должна работать примерно так же, как ниже представленный #define:
Посчитать количество строк в полученной функции. Факультативно: перечислить и обосновать преимущества перед приведенным #define.
Дано.
В программе есть некоторое количество классов, которые являются элементами односвязных списков с 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.
no subject
Date: 2009-07-20 07:25 am (UTC)no subject
Date: 2009-07-20 07:31 am (UTC)лисп и только лисп!
и пусть никто не уйдет...
no subject
Date: 2009-07-20 07:36 am (UTC)no subject
Date: 2009-07-20 07:36 am (UTC)no subject
Date: 2009-07-20 07:49 am (UTC)а лисп на смаллтолке пишецца в пять строк, ага.
(напевая "замыкая круг" уползает гордо распушив хвост)
no subject
Date: 2009-07-20 07:57 am (UTC)no subject
Date: 2009-07-20 08:16 am (UTC)заныкаю!
найти надо, очень старый кусок. позже, и, возможно - у себя вывалю
no subject
Date: 2009-07-20 08:21 am (UTC)no subject
Date: 2009-07-20 08:23 am (UTC)нахуа, пардон май френч?
один фиг, закину на стандалонку. куда-нить сюда кину ссыль как вспомню
no subject
Date: 2009-07-20 08:29 am (UTC)no subject
Date: 2009-07-20 08:52 am (UTC)я ж сказал - где нить ссылу брошу. не в жежешечку ж код пихать, шо я мазохист шоль?
no subject
Date: 2009-07-20 09:32 am (UTC)no subject
Date: 2009-07-20 10:41 am (UTC)когда для синхронизации известной по урлу (заметим, уникальному) - нужно перерыть пачку херни и найти внутренний ид....
нахуй-нахуй. лучше бы это писали пидорасы.
no subject
Date: 2009-07-20 10:51 am (UTC)no subject
Date: 2009-07-20 11:40 am (UTC)заодно можно распустить хвост и показать работкодателю. практически выложить на стол
no subject
Date: 2009-07-20 11:51 am (UTC)no subject
Date: 2009-07-20 11:57 am (UTC)no subject
Date: 2009-07-20 07:48 am (UTC)...без своей скобочки =)
нифига!
Date: 2009-07-20 08:54 am (UTC)no subject
Date: 2009-07-20 07:35 am (UTC)