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

stl sort vector не сортирует ?! - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вычисление площади треугольника по координатам x,y http://www.cyberforum.ru/cpp-beginners/thread908813.html
Привет, задали написать программу вычислить площади треугольника по координатам..данные координат берутся из файла и конечный результат записывается в файл.. А с файлами у меня очень туго..(
C++ Перегрузка функций Необходимо сделать перегрузку #include <iostream> #include <cstdlib> #include <clocale> #include <algorithm> using namespace std; int *InitArr(int *, int); void PrintArr(int *, int); bool DeleteValues(int *&, int, int &); http://www.cyberforum.ru/cpp-beginners/thread908769.html
C++ Вычислить координаты и значения экстремумов гамма-функции на отрезке (-2;2)
вычислить координаты и значения экстремумов гамма-функции на отрезке (-2;2) (вообще без разницы на каком языке)
C++ Функция в функции :-)
Привет! Задался дурацким вопросом :) Можно ли создать функцию внутри функции, чтоб её вызывать там всё время? Например: void Main() { void Child(){std::cout << "DIE YOU SON OF A ...." << std::endl;} .... //а где то в коде просто её вызывать типо Child(); Child(); :-) }
C++ как освободить память? http://www.cyberforum.ru/cpp-beginners/thread908754.html
Здравствуйте!!! Почему-то никак не освобождается память, выделенная оператором new под двумерный массив типа char,- как только идет освобождение, программа выдаем ошибку. #include<iostream> #include<cstring> using namespace std; const size_t AMOUNT_WORDS = 2; //максимальное кол-во слов const size_t MAX_LENGHT_WORD = 4; //размер слова(в реале будет на 1 символ меньше)
C++ нарисовать муравья помогите нарисовать муровья подробнее

Показать сообщение отдельно
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
21.06.2013, 17:32     stl sort vector не сортирует ?!
Ищите проблему в коде. sort тут ни при чем.
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
#include <iostream>
#include <vector>
#include <algorithm>
 
class Song
{
public:
   Song(const std::string& nm, int d) :
      name(nm), duration(d)
   {
   }
   int getSongLengthInMinutes() const
   {
      return duration;
   }
   std::string getSongName() const
   {
      return name;
   }
private:
   std::string name;
   int duration;
};
 
class PlaylistCompare
{
public:
   bool operator () (const Song& s1, const Song& s2) const
   {
      return s1.getSongLengthInMinutes() != s2.getSongLengthInMinutes() ?
         s1.getSongLengthInMinutes() > s2.getSongLengthInMinutes() :
         s1.getSongName() < s2.getSongName();
   }
};
 
int main()
{
   std::vector<Song> songs =
   {
      {"first", 3},
      {"second", 5},
      {"third", 2},
      {"other", 3}
   };
   PlaylistCompare greater;
   auto start = songs.begin(), end = songs.end();
   std::sort(start, end, greater);
   for (const Song& s : songs)
   {
      std::cout << s.getSongName() << " " << s.getSongLengthInMinutes() << std::endl;
   }
}
Код
second 5
first 3
other 3
third 2
 
Текущее время: 22:50. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru