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

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

29.11.2021, 17:35. Показов 1075. Ответов 0

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
#include <QtCore/QCoreApplication>
#include <iostream>
#include <stdio.h>
using namespace std;
void sort(int arr[],int n);
void input(int n,int arr[]);
void output(int arr[],int n);
bool goodDisposition(int x1, int x2);
 
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    int n;
    cout<<"Enter number of elements"<<endl;
    cin>>n;
    int arr[n];
    input(n,arr);
    sort(arr,n);
    output(arr,n);
    
    return a.exec();
}
void input(int n,int arr[]){
    for(int i=0; i<n; i++){
        cin>>arr[i];
    }
}
void output(int arr[],int n){
    for(int i=0; i<n; i++){
        printf("%d ",arr[i]);
    }
}
 
bool goodDisposition(int x1, int x2){
    if (x1 % 2 != x2 % 2) 
        
        return x1 % 2 < x2 % 2;
    else if( x1 % 2 == 0)  
        return x1 < x2;
    else    
        return x1 <  x2;
}
void sort(int arr[],int n){
    for(int i=1;i<n;i++){
        if(arr[i]<arr[i-1]){
            int buf = arr[i];
            int j=i;
            if(!goodDisposition(arr[i],arr[j])){
                do{
                    
                    arr[j]=arr[j-1];
                    j=j-1;
                }while(j!=0 && buf<arr[j-1]);
            }  arr[j]=buf;
            
        }
    }
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.11.2021, 17:35
Ответы с готовыми решениями:

Сортировка массива: сначала положительные по возрастанию, потом отрицательные по возрастанию
Пользователь вводит массив чисел,нужно отсортировать его методом выбора,что бы сначала шли...

Вывести сначала все парные элементы массива, потом — все непарные
Всем доброго времени суток! Я пока не силен в массивах, поэтому прошу помочь в решении задач: 1....

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

Отсортировать массив поставив сначала парные элементы потом непарные
Часть вроде получилось а с сортировкой не могу понять :-| Нужно Заполнить двумерный массив А...

Вывести матрицу в табличном виде сначала непарные числа а потом парные
Помогите с задачей: Заполнить матрицу случайными целыми неотрицательными числами. Вывести на экран...

0
29.11.2021, 17:35
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.11.2021, 17:35
Помогаю со студенческими работами здесь

Сортировка массива: сначала положительные числа по убыванию, потом отрицательные по возрастанию, потом нули
Заполнить массив рандомными числами от -100 включительно до 100 включительно. Отсортировать так:...

Сортировка массива: сначала расположит все отрицательные элементы, а потом - все положительные
Преобразовать массив таким образом, чтобы сначала располагались все отрицательные элементы, а потом...

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

Сортировка: сначала положительные числа по возрастанию, а потом - отрицательные тоже по возрастанию
Имеется код программы сортировки чисел. нужно чтобы сначала выводило положительные числа по...

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

Сортировка массива,чтобы сначала все числа отличные от нуля,а потом - нули
Здравствуйте,не могу понять в чём проблема.Метод Array.sort игнорирует всё,что идёт после второго...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru