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

Отсортировать четные элементы массива по возрастанию, а нечетные по убыванию

28.03.2020, 20:54. Показов 7404. Ответов 31

Студворк — интернет-сервис помощи студентам
Отсортировать четные элементы массива по возрастанию, а нечетные по убыванию
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.03.2020, 20:54
Ответы с готовыми решениями:

Отсортировать четные элементы массива по возрастанию, а нечетные по убыванию
помогите найти ошибку.не верно сортирует. #include <iostream> #include <math.h> #include<stdlib.h> #include<conio.h> ...

Отсортировать четные элементы массива по возрастанию, а нечетные по убыванию
По четным по возрастанию по нечетным по убыванию. Пробую пузырьковую сортировку не получается(

Отсортировать чётные элементы по возрастанию, а нечётные по убыванию
Вот условие(могу кое где ошибаться в правильности постановки задачи) Составить одномерный массив, в котором бы выводилось 20(или более)...

31
Отпрыск ChatGPT
 Аватар для Azawa
33 / 29 / 4
Регистрация: 18.06.2019
Сообщений: 152
28.03.2020, 21:19
Очевидный std::sort с лямбда-выражением проверки.

Добавлено через 3 минуты
Ошибаюсь. Интернет говорит — std::partition.
https://en.cppreference.com/w/... /partition
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
28.03.2020, 22:46  [ТС]
и как это реализовать? мне желательно методом пузырьков

Добавлено через 2 минуты
и как это реализовать? мне желательно методом пузырьков
0
199 / 155 / 45
Регистрация: 11.11.2019
Сообщений: 348
29.03.2020, 02:19
Лучший ответ Сообщение было отмечено ivan2020ua как решение

Решение

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
#include <iostream>
using namespace std;
 
int main()
{
    srand(123343);
 
    int sz;
    cout << "Input array size: ";
    cin >> sz;
 
    cout << "Original array:" << endl;
 
    // Create array
 
    int* array = new int[sz];
    for (int i = 0; i < sz; ++i)
    {
        array[i] = rand() % 50;
        cout << array[i] << ' ';        
    }
 
    // Bubble Sort
 
    bool sorted = false;
    for (int k = 0; k < sz - 2 && !sorted; ++k)
    {
        sorted = true;
        for (int j = 0; j < sz - k - 2; ++j)
        {
            if ((array[j] > array[j + 2]) == (j % 2))
            {
                swap(array[j], array[j + 2]);
                sorted = false;
            }
        }
    }
 
    // Output
 
    cout << endl << "Sorted array:" << endl;
    for (int i = 0; i < sz; ++i)        
    {
        cout << array[i] << ' ';        
    }
    delete[] array;
 
    return 0;
}
Первый вариант ориентируется на четные и нечетные позиции элементов. Второй вариант ориентируется на четные и нечетные значения элементов

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
#include <iostream>
using namespace std;
 
int findNext(int* array, int sz, int startpos, bool odd)
{
    for (int i = startpos; i < sz; ++i)
    {
        if (odd == static_cast<bool>(array[i] % 2)) return i;
    }
    return -1;
}
 
int main()
{
    srand(112);
 
    int sz;
    cout << "Input array size: ";
    cin >> sz;
 
    cout << "Original array:" << endl;
 
    // Create array
 
    int* array = new int[sz];
    for (int i = 0; i < sz; ++i)
    {
        array[i] = rand() % 50;
        cout << array[i] << ' ';        
    }
 
    // Bubble Sort
 
    bool sorted = false;
    for (int k = 0; k < sz - 1 && !sorted; ++k)
    {
        sorted = true;
        for (int j = 0; j < sz - k - 1; ++j)
        {           
            const bool odd = array[j] % 2;          
            const int next = findNext(array, sz - k, j + 1, odd);
 
            if (next > 0)
            {
                if ((array[j] < array[next]) == odd)
                {
                    swap(array[j], array[next]);
                    sorted = false;
                }
            }           
        }
    }
 
    // Output
 
    cout << endl << "Sorted array:" << endl;
    for (int i = 0; i < sz; ++i)        
    {
        cout << array[i] << ' ';        
    }
    delete[] array;
 
    return 0;
}
1
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.03.2020, 08:14
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
int main()
{
    srand((unsigned)time(0));
    int n;
    cout << "n="; cin >> n;
 
    int *a = new int[n];
    
    for (int i = 0; i < n; i++)
    {
        a[i]=rand()%9;
        cout << a[i] << " ";
    }
    cout << "\n";
    
    for (int i = 0; i < n-1; i++) 
    for (int j = i+1; j < n; j++)    
    if ((a[i]%2==0 && a[j]%2==0 && a[i]>a[j]) || (a[i]%2 && a[j]%2 && a[i]<a[j])) swap(a[i],a[j]); 
    
    for (int i = 0; i < n; i++) 
    cout << a[i] << " ";
    cout << "\n";
    
    delete[]a;    
system("pause");
return 0;
}
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
29.03.2020, 08:49  [ТС]
C:\Users\Lutyk\Desktop\ayeg\main.cpp|6|e rror: 'srand' was not declared in this scope|
C:\Users\Lutyk\Desktop\ayeg\main.cpp|19| error: 'rand' was not declared in this scope|
0
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22
29.03.2020, 10:10
ivan2020ua, вы кому пишете? К какому именно коду это имеет отношение?
Я проверил первый код из поста №4. VS2010 - всё нормально. Только добавил пару строк кода для удобства.
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
29.03.2020, 10:22  [ТС]
Argus19, я о первом коде , добавил
#include <cstdlib>
#include <ctime>
и все заработало

Добавлено через 2 минуты
мой вариант


#include <stdio.h>
#include <iostream>
using namespace std;
template <class T>//шаблон
void bubbleSort(T* arr, int n)//оголошення змінних
{


T tmp;

// бульбашкова сортування

for(int i = 0; i < (n-1)/2; ++i) // i - номер прохода
{
for(int j = 1; j < n-1; j+=2) // внутрішній цикл прохода
{
if (arr[j + 2] < arr[j])// елементи неврегульовані
{
tmp = arr[j + 2];
arr[j + 2] = arr[j];//міняємо місцями елементи
arr[j] = tmp;

}

}
}
}
int main()//оголошенн змінних
{
int a[10];
int arr[10];
int n, i;

printf("N: ");// виведення на екран N і зчитування
scanf("%i",&n);
for (i=0; i<n; ++i){ // 1 цикл
printf("a[%i] : ",i);
scanf("%i",&a[i]);
}

for (i=0; i<n; ++i)//циул для парних позицій
if (a[i]%2 == 0)//парні позиції
printf("%i\n",a[i]);//вивід на консоль
bubbleSort(a, n);//виклик сортування

for (i=n-1; i>=0; --i)//цикл для непарних позицій в порядку зменшення
if (a[i]%2 != 0)//непарні позиції
printf("%i\n",a[i]);//вивід на консоль

return 0;



все работает , только нужно вначале сделать безразмерный массив, а я хз как это сделать((
0
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22
29.03.2020, 10:35
Проверил все три приведённых кода, ошибок при компиляции нет.
Yetty, есть проблема. Заменил строку №16 на a[i]=rand()%50; и получил непонятный результат. По какому принципу сделана сортировка?
Миниатюры
Отсортировать четные элементы массива по возрастанию, а нечетные по убыванию  
0
 Аватар для Argus19
1427 / 444 / 78
Регистрация: 24.09.2017
Сообщений: 2,525
Записей в блоге: 22
29.03.2020, 10:37
ivan2020ua, оформите код правильно. Неудобно читать:
Миниатюры
Отсортировать четные элементы массива по возрастанию, а нечетные по убыванию  
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.03.2020, 10:45
Цитата Сообщение от Argus19 Посмотреть сообщение
По какому принципу сделана сортировка?
по условию
Цитата Сообщение от ivan2020ua Посмотреть сообщение
Отсортировать четные элементы массива по возрастанию, а нечетные по убыванию
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
29.03.2020, 10:48  [ТС]
Argus19,
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
#include <stdio.h>
#include <iostream>
using namespace std;
template <class T>//шаблон
void bubbleSort(T* arr, int n)//оголошення змінних
{
 
 
T tmp;
 
// бульбашкова сортування
 
for(int i = 0; i < (n-1)/2; ++i) // i - номер прохода
{
for(int j = 1; j < n-1; j+=2) // внутрішній цикл прохода
{
if (arr[j + 2] < arr[j])// елементи неврегульовані
{
tmp = arr[j + 2];
arr[j + 2] = arr[j];//міняємо місцями елементи
arr[j] = tmp;
 
}
 
}
}
}
int main()//оголошенн змінних
{
int a[10];
int arr[10];
int n, i;
 
printf("N: ");// виведення на екран N і зчитування
scanf("%i",&n);
for (i=0; i<n; ++i){ // 1 цикл
printf("a[%i] : ",i);
scanf("%i",&a[i]);
}
 
for (i=0; i<n; ++i)//циул для парних позицій
if (a[i]%2 == 0)//парні позиції
printf("%i\n",a[i]);//вивід на консоль
bubbleSort(a, n);//виклик сортування
 
for (i=n-1; i>=0; --i)//цикл для непарних позицій в порядку зменшення
if (a[i]%2 != 0)//непарні позиції
printf("%i\n",a[i]);//вивід на консоль
 
return 0;
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.03.2020, 10:57
ivan2020ua, Ваш код работает неправильно:
n=8
1 4 5 3 2 8 2 1
4 2 8 2 3 5 1 1
если Вам нужен код на языке С, раздел С здесь: http://www.cyberforum.ru/c-beginners/
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
29.03.2020, 11:08  [ТС]
Yetty, при N=10 все работает верно
он работает правильно, просто вы ввели две одинаковые цифры

Добавлено через 7 минут
Yetty, попробуйте в конце вместо еденици другую цифру
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.03.2020, 11:11
Цитата Сообщение от ivan2020ua Посмотреть сообщение
вы ввели две одинаковые цифры
Вы считаете что одинаковые вводить нельзя ? вот результат Вашего кода с разными:
n=10
1 4 5 3 2 8 6 9 7 0
4 2 8 6 0 9 7 3 5 1
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
29.03.2020, 11:17  [ТС]
Yetty, так тут все норм)

Добавлено через 1 минуту
Yetty, а можешь подсказать ,как сделать, чтобы четные позиции оставались на месте , а сортировались только нечетные?
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.03.2020, 11:22
Цитата Сообщение от ivan2020ua Посмотреть сообщение
Yetty, так тут все норм)
тяжеловато с Вами. давайте с самого начала:
массив
1 4 5 3 2 8 6 9 7 0
чётные массива выделены
1 4 5 3 2 8 6 9 7 0
чётные отсортированы по возрастанию
1 0 5 3 2 4 6 9 7 8

и где у Вас "норм" ?

Добавлено через 1 минуту
Цитата Сообщение от ivan2020ua Посмотреть сообщение
чтобы четные позиции оставались на месте
позиции не имеют никакого отношения к условию этой задачи
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
29.03.2020, 11:22  [ТС]
Yetty, четные позиции а не числа)
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
29.03.2020, 11:28
Цитата Сообщение от ivan2020ua Посмотреть сообщение
четные позиции а не числа
это Вы так решили. а в условии речь идёт о числах.

кстати если условие другое:
Отсортировать элементы на чётных позициях по возрастанию, на нечётных по убыванию
Ваш код тоже сортирует неправильно
0
3 / 2 / 1
Регистрация: 28.03.2020
Сообщений: 92
29.03.2020, 11:33  [ТС]
Yetty, и в чем собственно ошибка?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.03.2020, 11:33
Помогаю со студенческими работами здесь

Вывести нечётные по значению элементы массива по возрастанию, а чётные - по убыванию
Создал программку вот такую: #include &lt;iostream&gt; #include&lt;iomanip&gt; #include &lt;time.h&gt; using namespace std; void main() { ...

Отсортировать чётные столбцы матрицы по возрастанию, а нечётные – по убыванию
Нужно: Отсортировать чётные столбцы матрицы по возрастанию, а нечётные – по убыванию. Помогите пожалуйста кто-нибудь!

Отсортировать четные строки матрицы по возрастанию, а нечетные по убыванию
помогите пожалуйста с программой))) отсортировать четные строки матрицы M*N по возрастанию, а не четные по убыванию (чтоб запускалась...

Отсортировать четные столбцы матрицы по убыванию, нечетные по возрастанию (сортировка Шелла)
Богом прошу, помогите! Совершенно запутался. Необходимо: сортировкой Шелла с шагом d = N/2^i отсортировать четные столбцы по убыванию,...

Отсортировать массив: все четные элементы по возрастанию а нечетные по убыванию
отсортировать массив все четные элементы которого по возрастанию а не четные по убыванию


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru