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

Сортировать коллекцию структур по двум элементам - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Программа нахождения простых чисел http://www.cyberforum.ru/cpp-beginners/thread1784923.html
Я написал программу но в ней ошибка! Не пойму какая! Но мне важно понять как исправить именно эту прогу, знаю что есть другие проги на эту тему. #include<iostream> #include <iomanip> using...
C++ Как в векторе объектов пользовательского класса изменить заданное поле у определённого элемента? Добрый день. Создан вектор из структры: struct man { char name; int age; man(void) {} man(const char* hName, const int hAge) { strcpy(name, hName); age =... http://www.cyberforum.ru/cpp-beginners/thread1784901.html
C++ С концами запутался с operator overloading
Всем привет. Тема operator overloading - моё слабое место, очень хочу разобраться. Читаю всякие статейки (могу скинуть ссылки, если нужно) + учебник для чайников, но эта тема слишком обширная: в...
Skype API ошибка (_com_error_) C++
Пытаюсь изучать Skype API: #import "Skype4COM.dll" int main() { CoInitialize(NULL); SKYPE4COMLib::ISkypePtr pSkype(__uuidof(SKYPE4COMLib::Skype));
C++ Определить номер треугольного числа (последовательность A000217) http://www.cyberforum.ru/cpp-beginners/thread1784868.html
Напишите на языке C / C++ программу, определяющую номер треугольного числа (последовательность A000217 в «Энциклопедии целочисленных последовательностей»). Вход: одно целое (возможно, со знаком...
C++ Деление больших чисел (нужно ускорить) Ребятки, помогите ускорить. Уж очень медленно. Класс совсем простой(вектор со знаком): static const unsigned long long BASE = 1000000000; static const unsigned int BASE_DIGITS = 9; #define... подробнее

Показать сообщение отдельно
aiwprton805
70 / 70 / 26
Регистрация: 30.03.2013
Сообщений: 189
Завершенные тесты: 1
25.07.2016, 11:03
Так вам надо не сортировать, а просто отбросить ненужное.
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
#include <iostream>
#include <fstream>
#include <locale>
#include <list>
 
using namespace std;
 
class Node {
private:
    float x;
    float y;
public:
    Node() {
        x = 0.0;
        y = 0.0;
    }
 
    Node(float x, float y) {
        this->x = x;
        this->y = y;
    }
 
    bool operator== (Node node) const {
        return x == node.y && y == node.x;
    }
 
    friend ostream& operator<< (ostream& out, Node& node) {
        out << node.x << " " << node.y;
        return out;
    }
};
 
int main(int argc, char *argv[])
{
    setlocale(LC_ALL, "rus");
 
    list<Node> ilist;
    list<Node>::iterator i;
    list<Node>::iterator j;
    cout << "Введите точки" << endl;
    cout << "Конец ввода - ввод пустой строки" << endl;
    char *str = new char[51];
    while (1) {
        gets_s(str, 50);
        if (!strlen(str)) {
            break;
        }
        float x, y;
        sscanf_s(str, "%f %f", &x, &y);
        Node node(x, y);
        ilist.push_back(node);
    }
    delete[] str;
 
    cout << "Результат" << endl;
    for (i = ilist.begin(); i != ilist.end(); i++) {
        for (j = ilist.begin(); j != i; j++) {
            if (*i == *j) {
                cout << *j << endl << *i << endl;
            }
        }
    }
 
    ilist.clear();
 
    return 0;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru