0 / 0 / 0
Регистрация: 08.09.2016
Сообщений: 73
1

Сортировка четных, а затем нечетных элементов массива по возрастанию

20.09.2016, 10:53. Показов 7331. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста отсортировать массив. Сначала четные по возрастанию, а затем нечетные по возрастанию.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.09.2016, 10:53
Ответы с готовыми решениями:

Сортировка четных элементов массива по возрастанию, а нечетных-по убыванию
Задача в общем такая: Дан целочисленный массив.Отсортировать его четные элементы по возрастанию, а...

Сортировка четных столбцов матрицы по убыванию элементов, а нечетных - по возрастанию
Дана матрица, размерностью nxn, содержащая целые числа. Отсортировать каждый столбец матрицы с...

Вывод элементов массива, стоящих на четных позициях, а затем – на нечетных
добрый времени суток помогите решить задачку: разработайте программу, в которой реализован ввод...

Сортировка массива по возрастанию нечетных элементов
Помогите пожалуйста, мне нужно отсортировать одномерный массив так, чтобы сначала стояли...

7
8 / 8 / 6
Регистрация: 05.10.2015
Сообщений: 20
20.09.2016, 13:15 2
Как вариант, вот :

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
#include <iostream>
#include <cstdlib>
#include <algorithm>
#include <array>
#include <time.h>
 
 
 
int main(int argc, char *argv[])
{
    std::srand(time(NULL));
 
    const int size = 10;
    std::array<int, size> array;
 
    for(int i = 0; i < size; ++i)
    {
        array[i] = rand() % 100;
        std::cout << array[i] <<' ';
    }
    std::cout << '\n';
 
    int countEven = 0;
    int forwardID = 0;
    int backwardID = size-1;
 
    while(forwardID < backwardID)
    {
        while(array[forwardID] %2 ==0 && forwardID < backwardID)
        {
            ++countEven;
            ++forwardID;
        }
        while(array[backwardID] % 2 != 0 && forwardID < backwardID)
        {
        --backwardID;
        }
 
        std::swap(array[forwardID], array[backwardID]);
    }
 
    std::stable_sort(array.begin(), array.begin()+countEven);
    std::stable_sort(array.begin()+countEven, array.end());
 
    std::for_each(array.begin(), array.end(),[](int i){ std::cout << i << ' ';});
    std::cout << '\n';
 
}
1
Модератор
Эксперт CЭксперт С++
5279 / 2366 / 342
Регистрация: 20.02.2013
Сообщений: 5,766
Записей в блоге: 20
20.09.2016, 17:27 3
Цитата Сообщение от ShuricFC Посмотреть сообщение
Сначала четные по возрастанию, а затем нечетные по возрастанию.
ShuricFC, чётные и нечётные индексы элементов, номера элементов по порядку следования или значения элементов?

Добавлено через 3 часа 44 минуты
ShuricFC, а можно и так:

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
#include <iostream>
#include <algorithm>
#include <vector>
 
int main()
{
    const size_t ARR_SIZE = 11;
 
    int arr[ARR_SIZE] = { 21, 16, 81, 96, 71, 26, 51, 76, 91, 46, 31 };
 
    std::vector<int> vec( arr, arr + ARR_SIZE );
 
    size_t middle = ARR_SIZE/2;
 
    for ( size_t i = 0, j = 1; i < middle; ++i, j += 2)
        vec[i] = arr[j];
 
    for ( size_t i = middle, j = 0; i < ARR_SIZE; ++i, j += 2)
        vec[i] = arr[j];
 
    std::sort( vec.begin(), vec.begin() + middle, []( int x, int y ) { return x < y; } );
    std::sort( vec.begin() + middle, vec.end(), []( int x, int y ) { return x > y; } );
 
    std::cout << "Before sorting:\n";
    for ( const auto & elem : arr )
        std::cout << elem << " ";
 
    std::cout << "\n\nAfter sorting:\n";
    for ( const auto & elem : vec )
        std::cout << elem << " ";
 
    return 0;
}
0
Эксперт С++
1624 / 954 / 782
Регистрация: 06.02.2016
Сообщений: 2,452
Записей в блоге: 31
21.09.2016, 15:57 4
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
#include <iostream>
#include <string>
#include <algorithm>    // std::partition
#include <vector>
#include <ctime>
#include <cstdlib>
bool IsOdd (int i) {
    return i%2!=0;
}
using namespace std;
int main() {
    srand(time(nullptr));
    std::vector<int> myvector;
    for(int i=0; i!=10; i++) {
        myvector.push_back(rand()%20);
    }
    for(vector<int>::iterator iter= myvector.begin(); iter!= myvector.end(); iter++) {
        cout<<*iter<<" ";
    }
    partition (myvector.begin(), myvector.end(), IsOdd);
    sort(myvector.begin(),myvector.end(),[](int i,int j) {
        if(i%2==0 && j%2==0)
            return i<j;
    });
    sort(myvector.begin(),myvector.end(),[](int i,int j) {
        if(i%2!=0 && j%2!=0)
            return i<j;
    });
    cout<<endl;
    for (int i=1; i<10; ++i)
        cout<<myvector[i]<<" ";
    return 0;
}
1
Эксперт С++
3224 / 1751 / 435
Регистрация: 03.05.2010
Сообщений: 3,867
21.09.2016, 19:14 5
Лучший ответ Сообщение было отмечено ShuricFC как решение

Решение

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
//отсортировать массив. Сначала четные по возрастанию,
//а затем нечетные по возрастанию.
///////////////////////////////////////////////////////////////////////////////
#include <algorithm>
#include <iostream>
#include <iterator>
///////////////////////////////////////////////////////////////////////////////
int     main()
{
    const   int     ARR_SIZE            {9};
    int             arr[ ARR_SIZE ]     {};
 
    for(;;)
    {
        for( auto   &   elem    :   arr )
        {
            elem    =   rand() % ARR_SIZE + 1;
            std::cout   <<  elem    <<  '\t';
        }
        std::cout   <<  std::endl;
 
        std::sort
            (
                std::begin  ( arr ),
                std::end    ( arr )
            );
 
        std::stable_partition
            (
                std::begin  ( arr ),
                std::end    ( arr ),
                []          ( auto  elem )
                {
                    return  elem   %   2    ==  0;
                }
            );
 
        for( auto   elem    :   arr )
        {
            std::cout   <<  elem    <<  '\t';
        }
        std::cout   <<  std::endl;
        system("pause");
        std::cout   <<  std::endl;
    }//for
}
0
1718 / 567 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
21.09.2016, 21:41 6
Mr.X, может в 32 строке [] (int elem), а то что то с [] (auto elem) не компилируется.
0
Эксперт С++
3224 / 1751 / 435
Регистрация: 03.05.2010
Сообщений: 3,867
21.09.2016, 23:59 7
Цитата Сообщение от мановар Посмотреть сообщение
а то что то с [] (auto elem) не компилируется
С++14 надо подключить.
2
Модератор
Эксперт CЭксперт С++
5279 / 2366 / 342
Регистрация: 20.02.2013
Сообщений: 5,766
Записей в блоге: 20
22.09.2016, 07:14 8
Mr.X, красиво, очень. И просто. И само напрашивалось. Плюсую. Отличное решение.
0
22.09.2016, 07:14
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.09.2016, 07:14
Помогаю со студенческими работами здесь

Сортировка четных/нечетных элементов массива
В одномерном массиве состоящем из n вещественных элементов вычислить 1)... 2)... 3)упорядочить...

Сортировка четных и нечетных элементов массива
Упорядочить одномерный массив так, чтобы в начале располагались четные элементы в порядке...

Сортировка четных и нечетных элементов массива
ввести массив данных из N произвольных чисел и расположить четные из них от большего к меньшему, а...

Сортировка четных строк матрицы по возрастанию, а нечетных - по убыванию
Здравствуйте! Есть задача: отсортировать чётные строки массива А по возрастанию, а нечётные по...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru