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 12:31 pm (UTC)(link)
>closure - это, типа, чтобы не писать отдельную функцию ради того, чтобы поюзать
>return?

ну, не совсем. вот так, примерно:
function genCounter ()
  local i = 0;
  function cnt ()
    i = i+1;
    return i;
  end;
  return cnt;
end;

local f0, f1 = genCounter(), genCounter();
print(f0()); -- 1
print(f1()); -- 1


>continuations - в каком смысле yield-нуться? м.б. ты имел в виду чего-то
>подожидать?

function aaa ()
local f = 1;
print(f);
yield();
f = f+1;
print(f);
end;

aaa(); -- 1
aaa(); -- 2


второй пример некорректен по синтаксису, но по-сути показывает yield.

[identity profile] http://technorati.com/people/technorati/ketmar (from livejournal.com) 2009-07-20 12:33 pm (UTC)(link)
это Lua, есличо. %-)

[identity profile] psilogic.livejournal.com 2009-07-20 12:37 pm (UTC)(link)
да, continuations - тож прикольная фишечка