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

После каждого четного элемента массива вставить 2 элемента с тем же значением, полученный массив отсортировать

22.06.2013, 13:24. Показов 1598. Ответов 1
Метки нет (Все метки)

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

пример вывода на экран

исх массив 1 2 0 12 14
четные элементы 2 12 14
полученный отсортированный массив 14 14 14 12 12 12 2 2 2 1 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
#include <iostream>
#include <ctime>
using namespace std;
 
const int size = 10; 
int main()
    {  srand(time(0)); 
    setlocale (LC_CTYPE, "Russian");
    int arr[size]; 
    for (int i=0; i<size; i++)
 
        arr[i] = rand()%51; 
        int count = 0; 
    for (int i=0; i<size; i++)
        if ((arr[i]%2) == 0 && arr[i] != 0) 
            count++; 
        int* result = new int[count*3];
    int result_i = 0; 
    for (int i = 0; i<size; i++)
        {   if ((arr[i]%2) == 0 && arr[i] != 0) 
            for (int j=0; j<3; j++)
                result[result_i++] = arr[i];  }
    for (int i=0; i<count*3; i++)
        { for (int j=i+1; j<count*3; j++)
            { if (result[i] < result[j]) 
                {
                int temp = result[i];
                result[i] = result[j];
                result[j] = temp;
                }
            }
        }
    cout << "Исходный массив: ";
    for (int i=0; i<size; i++)
    cout << arr[i] << " ";
    cout << endl;
    cout << "Полученный отсортированный массив: ";
    for (int i=0; i<count*3; i++)
    cout << result[i] << " ";
    cout << endl;
    }
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.06.2013, 13:24
Ответы с готовыми решениями:

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

Добавить после каждого четного элемента массива элемент со значением M[ I+1 ]+2
Ребята помогите пожалуйста, вот условие данной задачи у меня сложности с 4 пунктом, почему-то элементы не ставятся после каждого четного,...

Добавить после каждого четного элемента массива элемент со значением M
Прошу помочь с решением задачи. 1)Сформировать одномерный массив целых чисел, используя датчик случайных чисел. 2)Распечатать...

1
 Аватар для JlightenDev_C++
64 / 64 / 33
Регистрация: 12.08.2012
Сообщений: 151
22.06.2013, 15:04
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
#include <iostream>
#include <ctime>
using namespace std;
 
const int size = 10;
 
int main(){
    srand(time(0)); 
    setlocale (LC_ALL, "Russian");
    int arr[size]; 
    for(int i = 0; i < size; i++) arr[i] = rand()%51;
    int count = 0;
    for(int i = 0; i < size; i++) if((arr[i]%2) == 0 && arr[i] != 0) count++;
    int t = size+count*2;
    int* result = new int[t];
    int result_i = 0; 
    for(int i = 0; i<size; i++){
            if((arr[i]%2) == 0 && arr[i] != 0)
            for (int j=0; j<3; j++) result[result_i++] = arr[i];
            else if(arr[i]%2 != 0)
            result[result_i++] = arr[i];
    }
    for (int i = 0; i < t; i++){
        for (int j=i+1; j<t; j++){
            if (result[i] < result[j]){
               int temp = result[i];
               result[i] = result[j];
               result[j] = temp;
            }
        }
    }
    cout << "Èñõîäíûé ìàññèâ: ";
    for(int i = 0; i < size; i++) cout << arr[i] << " ";
    cout << endl;
    cout << "Ïîëó÷åííûé îòñîðòèðîâàíííûé ìàññèâ: ";
    for(int i = 0; i < t; i++) cout << result[i] << " ";
    cout << endl;
    system("PAUSE >> void");
    return 0;
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.06.2013, 15:04
Помогаю со студенческими работами здесь

После каждого четного элемента массива вставить число К
Нужна после каждого четного элемента вставить число К.Я идею понял,но нужно учесть вариант что К тоже может быть четным иначе цикл может...

Динамические массивы: добавить после каждого четного элемента элемент со значением 0
помогите написать код, не шарю толком задачу, как можно целые числа заменить на k. суть задания: Сформировать одномерный массив целых...

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

Добавить после первого четного элемента массива элемент с заданным значением
Мне задали лабораторную работу, как всегда на самостоятельное изучение! Первый и второй пункт я сделала! Проблема с 3и4 пунктом. Хотелось...

Вставить в список число 66 после каждого элемента с отрицательным значением
Создать линейный двунаправленный список из целых чисел. Вставить в список число 66 после каждого элемента с отрицательным значением.


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru