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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.75
slipp1
13 / 12 / 1
Регистрация: 09.11.2012
Сообщений: 367
Записей в блоге: 1
#1

сортировка вектора sort() - C++

28.07.2013, 17:03. Просмотров 1881. Ответов 5
Метки нет (Все метки)

программа заполняет вектор рандомными числами в диапазоне от 1 до 100

сортирует с помощью алгоритма sort(.begin(),.end()) - в восходящем порядке
можно ли отсортировать с помощью 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
#include <iostream>
using namespace std;
#include <ctime>
 
#include <vector>
#include <iomanip>
using std::setw;
 
#include <algorithm>
 
void print(vector<int>);
int main(int argc, char *argv[])
 
{
    for(int i=1;i!=argc;i++)
    {
        cout<<argv[i]<<endl;
    }
 
    srand(int(time(0)));
 
    vector<int> massiv;
 
    for(int i=0;i!=100;i++)
    {
        massiv.push_back(1+rand()%100);
    }
    sort(massiv.begin(),massiv.end());
    print(massiv);
    return 0;
}
 
void print(vector<int> massiv)
{
    
    for(int i=0;i!=massiv.size();++i)
    {
        if(i%10==0)
        {
            cout<<endl;
        }
        cout<<setw(5)<<massiv[i]<<" ";
    }
    cout<<endl;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.07.2013, 17:03     сортировка вектора sort()
Посмотрите здесь:

Сортировка вектора через std::sort - C++
Доброго времени суток, интересует сабж void Sort(list&lt;int&gt; &amp;past) { sort(past.begin(), past.end()); } на такое выдает ...

Почему стандартная сортировка вектора std::sort намного быстрее сортировки вставками/пузырьком? - C++
Здравствуйте, объясните, пожалуйста, как реализована std::sort. Ясно, что через итераторы, но почему такой сильный выигрыш во времени (1.4...

q-sort сортировка - C++
Здраствуйте , не могу понять где в коде ошибка . Выдает такое :d:\program...

Сортировка Quick Sort - C++
Можно написать код и коментами.

Не работает сортировка Stl sort - C++
вот код сортировки массива обычным stl sort () #include&lt;conio.h&gt; #include&lt;iostream.h&gt; #include&lt;vector.h&gt; #include&lt;algorithm&gt; ...

Сортировка слиянием (Merge sort) - C++
Пожалуйста, помогите сортировать лист в C++ только надо именно слиянием отсортировать

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Bend3r
149 / 136 / 18
Регистрация: 29.07.2012
Сообщений: 709
28.07.2013, 17:06     сортировка вектора sort() #2
Создай свою сортировку что-то типо:
C++
1
2
3
4
5
6
7
8
for(int i = 0; i < massiv[i]; i++)
for(int j = i+1; j < massiv[j]; j++)
if(massiv[i] > massiv[j]
{
int temp = massiv[i];
massiv[i] = massiv[j];
massiv[j] = temp;
}
И просто при сравнивание чисел в массиве, просто поменяй знак. И у тебя будет сортировка в нисходящем порядке.
slipp1
13 / 12 / 1
Регистрация: 09.11.2012
Сообщений: 367
Записей в блоге: 1
28.07.2013, 17:11  [ТС]     сортировка вектора sort() #3
C++
1
reverse(massiv.begin(),massiv.end());
спасибо.
gray_fox
What a waste!
1447 / 1176 / 61
Регистрация: 21.04.2012
Сообщений: 2,463
Завершенные тесты: 3
28.07.2013, 17:30     сортировка вектора sort() #4
C++
1
2
3
4
5
#include <functional>
 
// ...
 
sort(massiv.begin(), massiv.end(), greater<int>());
slipp1
13 / 12 / 1
Регистрация: 09.11.2012
Сообщений: 367
Записей в блоге: 1
28.07.2013, 21:25  [ТС]     сортировка вектора sort() #5
Цитата Сообщение от gray_fox Посмотреть сообщение
C++
1
2
3
4
5
#include <functional>
 
// ...
 
sort(massiv.begin(), massiv.end(), greater<int>());
C++
1
greater<int>
такова логика? - разрешает работу функции sort() если x > y - возвращает true?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.07.2013, 21:31     сортировка вектора sort()
Еще ссылки по теме:

Сортировка индексов алгоритмом std::sort - C++
Есть два массива одинаковой размерности. В одном хоть что, во втором целые числа (индексы элементов первого массива). Нужно выполнить...

Сортировка списка с использованием std::sort - C++
Что-то не получается отсортировать целочисленные данные расположенные в списке, компилятор (VS10) жутко ругается. В чем может быть дело? ...

Сортировка массива объектов функцией sort - C++
Не получается отсортировать массив объектов. После сортировки должен вывестись список отсортированных по мощности объектов. Код криворукий,...

Sort vector, сортировка по двум полям структуры - C++
Поскажите как отсортировать если: struct DATA{ string fir; string sec; double sm; }; vector &lt;DATA&gt; vec; vector...

(STL LIST SORT) Сортировка по некольким критериям - C++
Здравствуйте! Столкнулся с такой проблемой при сортировке списка. %-) Есть структура: struct PackObject { bool ...

Сортировка объектов функцией sort() по данным объекта - C++
Есть класс Man, при создании его объекта в вектор &quot;люди&quot; должно заносить этот объект. После вызова ф-ции сортировки должно сортировать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Croessmah
Модератор
Эксперт CЭксперт С++
13057 / 7320 / 817
Регистрация: 27.09.2012
Сообщений: 18,061
Записей в блоге: 3
Завершенные тесты: 1
28.07.2013, 21:31     сортировка вектора sort() #6
Передается предикат
http://www.cplusplus.com/reference/functional/greater/
который будет использоваться для сравнения
Yandex
Объявления
28.07.2013, 21:31     сортировка вектора sort()
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru