Форум программистов, компьютерный форум, киберфорум С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 04.05.2017
Сообщений: 60
1

Векттра

20.12.2017, 15:42. Показов 865. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
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
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <iomanip>
#include <iterator>
using namespace std;
 
class Student {
 
private:
    string name;
    string surname;
 
 
 
public:
    Student(string name, string surname):name(name), surname(surname){};
    Student(const Student& student) :name(student.name), surname(student.surname){};
 
    Student& operator=(const Student& student) {
        name = student.name;
        surname = student.surname;
        return *this;
    }
 
    int CompareName(const Student& student) const {
        return name.compare(student.name);
    }
 
    int CompareSurname(const Student& student) const {
        return surname.compare(student.surname);
    }
 
    friend ostream& operator<< (ostream& stream, const Student& student) {
        stream << "   Name:" << setw(10) << student.name;
        stream << "   Surname:" << setw(10) << student.surname << endl;
        return stream;
    }
};
 
void Init(vector<Student>& students);
void Print(const vector<Student>& students);
 
int main()
{
    vector<Student> students;
 
    Init(students);
    cout << "Original list: :" << endl;
    Print(students);
 
 
    sort(students.begin(), students.end(), [](const Student& left, const Student& right) {return left.CompareName(right) < 0; });
    cout << "\nSorted ascending by name:" << endl;
    Print(students);
 
 
    sort(students.begin(), students.end(), [](const Student& left, const Student& right) {return left.CompareSurname(right) < 0; });
    cout << "\nSorted descending by surname:" << endl;
    Print(students);
 
    return 0;
}
void Init(vector<Student>& students) {
    students.push_back("Vasiliy", "Petrov");
    students.push_back("Oleg", "Golova");
    students.push_back("Maxim", "L");
    students.push_back("Dmitriy", "K");
    students.push_back("Andrey", "A");
    students.push_back("Vladislav", "G");
}
 
void Print(const vector<Student>& students) {
        cout << students;
}
Не компилируется
0
Лучшие ответы (1)
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
20.12.2017, 15:54 2
Текст ошибок где?
0
2355 / 1842 / 756
Регистрация: 27.07.2012
Сообщений: 5,459
20.12.2017, 15:57 3
C++ Скопировано
1
2
3
4
5
6
7
8
void Init(vector<Student>& students) {
    students.push_back(Student("Vasiliy", "Petrov"));
    students.push_back(Student("Oleg", "Golova"));
    students.push_back(Student("Maxim", "L"));
    students.push_back(Student("Dmitriy", "K"));
    students.push_back(Student("Andrey", "A"));
    students.push_back(Student("Vladislav", "G"));
}
0
0 / 0 / 0
Регистрация: 04.05.2017
Сообщений: 60
20.12.2017, 16:09  [ТС] 4
error: no matching function for call to 'sort(std::vector<Student>::iterator, std::vector<Student>::iterator, main()::<lambda(const Student&, const Student&)>)'|

Добавлено через 33 секунды
там очень много ошибок

Добавлено через 1 минуту
|60|error: template argument for 'template<class _RAIter, class _Compare> void std::sort(_RAIter, _RAIter, _Compare)' u
ses local type 'main()::<lambda(const Student&, const Student&)>'|
|76|error: no match for 'operator<<' (operand types are 'std::ostream {aka std::basic_ostream<char>}' and 'const std::vector<Student>')|
0
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
20.12.2017, 16:13 5
То, что в 3-ем сообщении написали, сделал?
75-ю строку замени циклом.
0
0 / 0 / 0
Регистрация: 04.05.2017
Сообщений: 60
20.12.2017, 16:20  [ТС] 6
C++ Скопировано
1
2
3
4
void Print(const vector<Student>& students) {
       for (const Student& student : students)
            cout << students;
}
|76|error: range-based 'for' loops are not allowed in C++98 mode|
|77|error: no match for 'operator<<' (operand types are 'std::ostream {aka std::basic_ostream<char>}' and 'const std::vector<Student>')|
0
7803 / 6567 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
20.12.2017, 16:48 7
Лучший ответ Сообщение было отмечено lapsha1337 как решение

Решение

C++ Скопировано
1
2
3
4
5
void Print(const vector<Student>& students)
{
       for (const Student& student : students)
            cout << student;
}
Цитата Сообщение от lapsha1337 Посмотреть сообщение
|76|error: range-based 'for' loops are not allowed in C++98 mode|
Включи поддержку C++11.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Ответ Создать тему

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Лучшие практики оптимизации Docker Image
Mr. Docker 13.03.2025
Размер Docker-образа влияет на множество аспектов работы с контейнерами. Чем больше образ, тем дольше его загрузка в реестр и выгрузка из него. Для команд разработки, работающих с CI/ CD пайплайнами,. . .
Вопросы на собеседовании по Docker
Mr. Docker 13.03.2025
Ты сидишь напротив технического специалиста, и вдруг звучит вопрос про Docker Swarm или многоэтапные сборки. Пот на лбу? Не переживай, после этой статьи ты будешь готов ко всему! Эта статья будет. . .
Поиск текста в сносках : замена дефиса на тире или тире на дефис...
РоΜа 13.03.2025
Нужно было найти текст в сносках и заменить. Почему-то метод селекшн не сработал. . . пришлось гуглить. найденный на форумвба код пришлось править. Смысл - заменяет в сносках дефисы и тире на нужные. . . .
Real PATH definitions in bash scripts
jigi33 13.03.2025
Как поймать путь и путь к директории относительно запускаемого файла в BASH 1. поймать путь через вывод $(pwd) 2. более правильно - на основе realpath (см. скриншот)
Django или Flask: что выбрать для веб-разработки на Python
py-thonny 13.03.2025
Django – это высокоуровневый фреймворк, который придерживается философии "всё включено". Он предоставляет разработчику готовые решения для большинства типичных задач веб-разработки: от аутентификации. . .
Непрерывное развертывание в Java с Kubernetes
Javaican 13.03.2025
Чем так привлекателен Kubernetes для развертывания Java-приложений? Этот оркестратор контейнеров позволяет автоматизировать развертывание, масштабирование и управление контейнеризированными. . .
Предотвращение XSS, CSRF и SQL-инъекций в JavaScript
run.dev 13.03.2025
JavaScript занимает первые позиции среди языков веб-разработки, но его распространенность делает его привлекательной целью для злоумышленников. Межсайтовый скриптинг (XSS), межсайтовая подделка. . .
PHP 8: JIT-компиляция и улучшение производительно­сти
Jason-Webb 13.03.2025
PHP никогда не славился своей скоростью. Многие сталкивались с проблемами производительности при работе со сложными вычислениями или обработкой больших объемов данных. Традиционная модель выполнения. . .
Сериализация данных с Apache Avro в Kafka
Javaican 12.03.2025
Apache Kafka стала одним из ключевых решений для работы с большими потоками данных. Однако с ростом объемов передаваемых данных возникает проблема: как эффективно сериализовать и десериализовать. . .
Создание потребителей Kafka с помощью Reactor Kafka
Javaican 12.03.2025
Reactor Kafka — это библиотека, объединяющая Apache Kafka с реактивным программированием на базе Project Reactor. Такое сочетание позволяет строить неблокирующие, асинхронные приложения с контролем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер