Читаем C++ для начинающих полностью

stable_partition( &ia[0], &ia[12], even_elem() );

cout "устойчивое разбиение по четным элементам:\n";

copy( ia, ia+11, ofile ); cout '\n';

stable_partition( vec.begin(), vec.end(),

bind2nd(lessint(),25) );

cout "устойчивое разбиение по элементам, меньшим 25:\n";

copy( vec.begin(), vec.end(), ofile ); cout '\n';

}

<p>Алгоритм stable_sort()</p>

templateclass RandomAccessIterator

void

stable_sort( RandomAccessIterator first,

RandomAccessIterator last );

template class RandomAccessIterator, class Compare

void

stable_sort( RandomAccessIterator first,

RandomAccessIterator last, Compare comp );

stable_sort() ведет себя так же, как sort(), но гарантированно сохраняет относительный порядок равных элементов контейнера. Второй вариант упорядочивает элементы на основе заданной программистом операции сравнения comp.

#include algorithm

#include vector

#include iostream.h

/* печатается:

исходная последовательность:

29 23 20 22 12 17 15 26 51 19 12 23 35 40

устойчивая сортировка - по умолчанию в порядке возрастания:

12 12 15 17 19 20 22 23 23 26 29 35 40 51

устойчивая сортировка: в порядке убывания:

51 40 35 29 26 23 23 22 20 19 17 15 12 12

*/

int main()

{

int ia[] = { 29,23,20,22,12,17,15,26,51,19,12,23,35,40 };

vector int, allocator vec( ia, ia+14 );

ostream_iterator int ofile( cout, " " );

cout "исходная последовательность:\n";

copy( vec.begin(), vec.end(), ofile ); cout '\n';

stable_sort( &ia[0], &ia[14] );

cout "устойчивая сортировка - по умолчанию "

"в порядке возрастания:\n";

copy( ia, ia+14, ofile ); cout '\n';

stable_sort( vec.begin(), vec.end(), greaterint() );

cout "устойчивая сортировка: в порядке убывания:\n";

copy( vec.begin(), vec.end(), ofile ); cout '\n';

}

<p>Алгоритм swap()</p>

template class Type

void

swap ( Type &ob1, Type &ob2 );

swap() обменивает значения объектов ob1 и ob2.

#include algorithm

#include vector

#include iostream.h

/* печатается:

исходная последовательность:

3 4 5 0 1 2

после применения swap() в процедуре пузырьковой сортировки:

0 1 2 3 4 5

*/

int main()

{

int ia[] = { 3, 4, 5, 0, 1, 2 };

vectorint, allocator vec( ia, ia+6 );

for ( int ix = 0; ix 6; ++ix )

for ( int iy = ix; iy 6; ++iy ) {

if ( vec[iy] vec[ ix ] )

swap( vec[iy], vec[ix] );

}

ostream_iterator int ofile( cout, " ");

cout "исходная последовательность:\n";

copy( ia, ia+6, ofile ); cout '\n';

cout "после применения swap() в процедуре "

"пузырьковой сортировки:\n";

copy( vec.begin(), vec.end(), ofile ); cout '\n';

}

<p>Алгоритм swap_ranges()</p>

template class ForwardIterator1, class ForwardIterator2

ForwardIterator2

swap_ranges( ForwardIterator1 first1, ForwardIterator1 last,

ForwardIterator2 first2 );

Перейти на страницу:

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных