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

Приведите в порядок по возрастанию отдельно элементы, стоящие на четных местах, и ​​элементы на нечетных (в чем ошибка)?

14.11.2019, 00:16. Показов 2537. Ответов 11

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
    using namespace std;
    int main()
    {
        setlocale(LC_ALL, "rus");
        int N;
        cout << "Введите N= ";
        cin >> N;
        int* A = new int[N];
        for (int i = 0; i < N; i++)
        {
            cout << "A[" << i << "]=";
            cin >> A[i];
        }
        cout << "A:";
        for (int i = 0; i < N; i++)
        {
 
 
            if (A[i] > 0) A[i] += 2;
            if (A[i] < 0) A[i] -= 2;
            cout << A[i] << " ";
        }
        
        cout << endl;
        system("pause");
        return 0;
    }
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.11.2019, 00:16
Ответы с готовыми решениями:

Упорядочить по возрастанию значений отдельно элементы, стоящие на четных местах, и элементы, стоящие на нечетных местах
#include&lt;iostream&gt; #include&lt;algorithm&gt; #include&lt;vector&gt; using namespace std; int main() { int n,ind1=0,ind2=0; ...

Упорядочить по возрастанию отдельно элементы, стоящие на четных местах, и элементы, стоящие на нечетных местах
В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1) сумму элементов массива, расположенных после минимального...

Упорядочить по возрастанию отдельно элементы, стоящие на четных местах, и элементы на нечетных
помогите: В одномерном массиве, состоящем из n вещественных элементов: Упорядочить по возрастанию отдельно элементы, стоящие на...

11
Модератор
 Аватар для long399
2882 / 1836 / 933
Регистрация: 16.10.2013
Сообщений: 5,236
Записей в блоге: 15
14.11.2019, 05:09
Цитата Сообщение от bettersweet Посмотреть сообщение
if (A[i] > 0) A[i] += 2;
if (A[i] < 0) A[i] -= 2;
cout << A[i] << " ";
Зачем это делается? Для меня непонятно.

Насчет сортировки, можно легко обойтись двумя сортировками пузырька, пробегающихся по нужным элементам (четным и нечетным)
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
#include <iostream>
using namespace std;
 
int main(){
setlocale(LC_ALL, "rus");
int N, tmp;
cout << "Введите N= ";
cin >> N;
int* A = new int[N];
for (int i = 0; i < N; i++){
cout << "A[" << i << "]=";
cin >> A[i];
}
 
// нечетн.
for (int i = 0; i < N; i+=2){
    for(int j = 0; j < N - 2; j+=2)
    if (A[j] > A[j + 2]) {
        tmp = A[j];
        A[j] = A[j+2];
        A[j+2] = tmp;
    }
}
// четн.
for (int i = 1; i < N; i+=2){
    for(int j = 1; j < N - 2; j+=2)
    if (A[j] > A[j + 2]) {
        tmp = A[j];
        A[j] = A[j+2];
        A[j+2] = tmp;
    }
}
for (int i = 0; i < N; i++)
    cout << A[i] << " ";
cout << endl;
system("pause");
return 0;
}
1
0 / 0 / 0
Регистрация: 30.10.2019
Сообщений: 12
14.11.2019, 10:22  [ТС]
if (A[i] > 0) A[i] += 2;
if (A[i] < 0) A[i] -= 2;
cout << A[i] << " ";
Это увеличивает элементы больше 0 на 2, и отнимает 2 от элементов меньше 0.
И нужно результат этого кода отсортировать отдельно числа, стоящие на четных местах от чисел стоящих на нечетных местах по возрастанию
0
Модератор
 Аватар для long399
2882 / 1836 / 933
Регистрация: 16.10.2013
Сообщений: 5,236
Записей в блоге: 15
14.11.2019, 10:42
Лучший ответ Сообщение было отмечено bettersweet как решение

Решение

bettersweet, ну тогда вернуть этот момент в код надо:

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;
 
int main(){
setlocale(LC_ALL, "rus");
int N, tmp;
cout << "Введите N= ";
cin >> N;
int* A = new int[N];
for (int i = 0; i < N; i++){
cout << "A[" << i << "]=";
cin >> A[i];
}
 
cout << "A: ";
for (int i = 0; i < N; i++){
if (A[i] > 0) A[i] += 2;
if (A[i] < 0) A[i] -= 2;
cout << A[i] << " ";
}
 
// нечетн.
for (int i = 0; i < N; i+=2){
    for(int j = 0; j < N - 2; j+=2)
    if (A[j] > A[j + 2]) {
        tmp = A[j];
        A[j] = A[j+2];
        A[j+2] = tmp;
    }
}
// четн.
for (int i = 1; i < N; i+=2){
    for(int j = 1; j < N - 2; j+=2)
    if (A[j] > A[j + 2]) {
        tmp = A[j];
        A[j] = A[j+2];
        A[j+2] = tmp;
    }
}
for (int i = 0; i < N; i++)
    cout << endl << A[i] << " ";
cout << endl;
system("pause");
return 0;
}
1
0 / 0 / 0
Регистрация: 30.10.2019
Сообщений: 12
14.11.2019, 22:34  [ТС]
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;
 
int main(){
setlocale(LC_ALL, "rus");
int N, tmp;
cout << "Введите N= ";
cin >> N;
int* A = new int[N];
for (int i = 0; i < N; i++){
cout << "A[" << i << "]=";
cin >> A[i];
}
 
cout << "A: ";
for (int i = 0; i < N; i++){
if (A[i] > 0) A[i] += 2;
if (A[i] < 0) A[i] -= 2;
cout << A[i] << " ";
}
 
// нечетн.
for (int i = 0; i < N; i+=2){
    for(int j = 0; j < N - 2; j+=2)
    if (A[j] > A[j + 2]) {
        tmp = A[j];
        A[j] = A[j+2];
        A[j+2] = tmp;
    }
}
// четн.
for (int i = 1; i < N; i+=2){
    for(int j = 1; j < N - 2; j+=2)
    if (A[j] > A[j + 2]) {
        tmp = A[j];
        A[j] = A[j+2];
        A[j+2] = tmp;
    }
}
for (int i = 0; i < N; i++)
    cout << endl << A[i] << " ";
cout << endl;
system("pause");
return 0;
}
Добавлено через 8 минут
Если что, отрицательные числа должны уменьшаться на 2, а числа больше 0 - увеличиваться на 2, это не ошибка.
0
Заяц, просто Заяц.
 Аватар для Fury67
666 / 280 / 156
Регистрация: 12.11.2017
Сообщений: 882
14.11.2019, 22:36
bettersweet, вставьте код в читабельном виде, используя команды, которые есть на панели ввода. Пока этого не сделаете, вам точно никто помогать не будет.
Пример:
C++ (Qt)
1
Здесь пишут код
0
Заяц, просто Заяц.
 Аватар для Fury67
666 / 280 / 156
Регистрация: 12.11.2017
Сообщений: 882
15.11.2019, 00:00
Теперь работает. Проверьте.

C++ (Qt)
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 <iostream>
using namespace std;
 
int main() {
    setlocale(LC_ALL, "rus");
    int N, tmp;
    cout << "Введите N= ";
    cin >> N;
    int* A = new int[N];
    for (int i = 0; i < N; i++) {
        cout << "A[" << i << "]=";
        cin >> A[i];
    }
 
    cout << "A: ";
    for (int i = 0; i < N; i++) {
        if (A[i] > 0) A[i] += 2;
        if (A[i] < 0) A[i] -= 2;
        cout << A[i] << " ";
    }
 
    // нечетн.
    for (int i = 0; i < N; i += 2) {
        for (int j = 0; j < N; j += 2)
            if (A[i] < A[j]) {
                tmp = A[j];
                A[j] = A[i];
                A[i] = tmp;
            }
    }
    // четн.
    for (int i = 1; i < N; i += 2) {
        for (int j = 1; j < N; j += 2)
            if (A[i] < A[j]) {
                tmp = A[j];
                A[j] = A[i];
                A[i] = tmp;
            }
    }
    cout << endl;
    for (int i = 0; i < N; i++)
        cout << A[i] << " ";
    cout << endl;
    system("pause");
    return 0;
}
0
0 / 0 / 0
Регистрация: 30.10.2019
Сообщений: 12
18.11.2019, 20:57  [ТС]
Всё равно работает не так как нужно. Ответ выводит, не меняя порядок, а должны выводится отдельно элементы, стоящие на четных местах, и отдельно ​​элементы, стоящие на нечетных.
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
18.11.2019, 21:09
Цитата Сообщение от bettersweet Посмотреть сообщение
должны выводится отдельно элементы, стоящие на четных местах, и отдельно ​​элементы, стоящие на нечетных
если Вы прочитаете условие, отдельно элементы должны не выводиться, а сортироваться (приводиться в порядок по возрастанию). например из массива 9 5 6 3 1 4 8 должен получиться массив 1 3 6 4 8 5 9
1
0 / 0 / 0
Регистрация: 30.10.2019
Сообщений: 12
18.11.2019, 21:16  [ТС]
Всё же, эта программа должна сортировать отдельно стоящие на четных местах, и отдельно ​​элементы, стоящие на нечетных,
а эта даже по возрастанию не сортирует
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
18.11.2019, 21:49
Цитата Сообщение от bettersweet Посмотреть сообщение
эта даже по возрастанию не сортирует
программа из сообщения №2 этой темы отсортирует массив так, как требуется по условию
1
0 / 0 / 0
Регистрация: 30.10.2019
Сообщений: 12
18.11.2019, 22:23  [ТС]
Спасибо, я наконец понял)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.11.2019, 22:23
Помогаю со студенческими работами здесь

Упорядочить по возрастанию отдельно элементы массива, стоящие на четных и нечетных местах
Упорядочить по возрастанию отдельно элементы, стоящие на четных местах, и элементы, стоящие на нечетных местах. Попрошу все написать...

Сортировка массива: отдельно элементы, стоящие на четных местах и элементы, стоящие на нечетных местах
здравствуйте! задание: В одномерном массиве, состоящем из п целых элементов. Упорядочить по возрастанию отдельно элементы, стоящие на...

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

Упорядочить элементы, стоящие на четных местах, по возрастанию, а элементы на нечетных местах - по убыванию
Задание: дан линейный массив из n элементов. Упорядочить элементы, стоящие на четных местах, по возрастанию, а элементы на нечетных местах...

Упорядочить по возрастанию отдельно элементы, стоящие на четных местах
с использованием процедур и функций ,реализованных в подключенных модулях Даны целые числа a(1), a(2), ..a(n). а) сортировать каждые k...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru