Форум программистов, компьютерный форум CyberForum.ru

Адаптеры, стандартные алгоритмы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ В фразе поменять местами два слова http://www.cyberforum.ru/cpp-beginners/thread398283.html
всем привет...помогите написать программу...буду очень благодарен тема: строки символов. С клавиатуры вводится фраза...В фразе поменять местами два слова.
C++ Вывести номера столбцов , в которых находиться более двух простых чисел Задана матрица целых чисел A(n,n). Вывести номера столбцов , в которых находиться более двух простых чисел.Найти сумму положительных элементов на периметре матрицы. Хоть намекните как.Спасибо. http://www.cyberforum.ru/cpp-beginners/thread398279.html
C++ Смещение по файлу!
Подскажите как передвинуть файловый указатель на размер строки, то есть перейти к следующей!=) Добавлено через 27 минут Да и к пред идущей!
Обновлении записи в связанном списке C++
Здравствуйте. Пишу код для GUI приложения. По заданию я обязан сделать функцию, которая бы изменяла запись в базе данных, возвращалась позиция записи в соответствии с порядком сортировки. Так же любой перебор элементов обязан делать только итераторами. Обязан использовать контейнер QLinkedList. Аргументы функции указаны в коде с комментариями. /** Изменить запись в базе данных \param id - ...
C++ Карточная игра http://www.cyberforum.ru/cpp-beginners/thread398251.html
Здравствуйте! Есть карточная игра, нужно сделать программу для игры на компьютере и далее, чтобы можно было играть в интернете в нее онлайн с живыми людьми. сколько будет стоить? Для жителей Санкт-Петербурге!!!!!
C++ Переведите с Паскаля Всем привет! Нарыл в инете прогу на Паскале (прога определяет день недели по дате). Нужно перевести ее на С++ program denned; const YEARS : array of byte = (0, 2, 3, 4); подробнее

Показать сообщение отдельно
cyt
1 / 1 / 0
Регистрация: 01.10.2010
Сообщений: 47
04.12.2011, 01:36     Адаптеры, стандартные алгоритмы
Не получается организовать сортировку (закоментировано). Надо использовать адаптеры и стандартные алгоритмы. Подскажите, плиз

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#include <iostream>
#include <algorithm>
#include <functional>
#include <list>
using namespace std;
 
class Shape
{
public:
    int isMoreLeft(Shape &); // Левее по оси x?
    int isUpper(Shape &);    // Выше по оси y?
    virtual void Draw() const = 0;
    int x, y;
};
int Shape::isMoreLeft(Shape &s)
{
    if(x < s.x)
        return 1;
    else
        return 0;
}
/* Возможно надо так???
bool Shape::isMoreLeft(Shape &s1, Shape &s2)
{
    return s1.x < s2.x;
}
*/
int Shape::isUpper(Shape &s)
{
    if(y > s.y)
        return 1;
    else
        return 0;
}
/* Возможно надо так???
bool Shape::isUpper(Shape &s1, Shape &s2)
{
    return s1.y > s2.y;
}
*/
 
class Circle : public Shape
{
public:
    Circle(int = 0, int = 0);
    virtual void Draw() const;
};
Circle::Circle(int a, int b)
{
    x = a;
    y = b;
}
void Circle::Draw() const
{
    cout << "Circle (" << x << "," << y << ");" << endl;
}
 
class Triangle : public Shape
{
public:
    Triangle(int = 0, int = 0);
    virtual void Draw() const;
};
Triangle::Triangle(int a, int b)
{
    x = a;
    y = b;
}
void Triangle::Draw() const
{
    cout << "Triangle (" << x << "," << y << ");" << endl;
}
 
class Square : public Shape
{
public:
    Square(int = 0, int = 0);
    virtual void Draw() const;
};
Square::Square(int a, int b)
{
    x = a;
    y = b;
}
void Square::Draw() const
{
    cout << "Square (" << x << "," << y << ");" << endl;
}
int main()
{
    list<Shape*> figures; 
 
    figures.push_back(new Circle(1, 2));
    figures.push_back(new Triangle(2, 3));
    figures.push_back(new Square(0, 2));
 
    for_each(figures.begin(), figures.end(), mem_fun(&Shape::Draw)); // Печать
 
    //sort(figures.begin(), figures.end(), mem_fun(&Shape::isMoreLeft)); // Сортировка по x (возрастание)
    for_each(figures.begin(), figures.end(), mem_fun(&Shape::Draw)); // ...
 
    //sort(figures.begin(), figures.end(), mem_fun(&Shape::isMoreLeft)); // Сортировка по x (убывание), используя отрицатель
    for_each(figures.begin(), figures.end(), mem_fun(&Shape::Draw)); // ...
 
    //sort(figures.begin(), figures.end(), mem_fun(&Shape::isUpper)); // Сортировка по y (возрастание)
    for_each(figures.begin(), figures.end(), mem_fun(&Shape::Draw)); // ...
 
    //sort(figures.begin(), figures.end(), mem_fun(&Shape::isUpper)); // Сортировка по y (убывание), используя отрицатель
    for_each(figures.begin(), figures.end(), mem_fun(&Shape::Draw)); // ...
 
    cout << endl;
 
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 10:58. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru