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

Поменять местами элементы массива, стоящие на чётных местах, с элементами, стоящими на нечетных

16.08.2017, 17:38. Показов 1352. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Реализовать два способа задания массивов: ввод значений с клавиатуры и заполнение случайными числами. Для каждого способа реализовать вывод получившегося массива на экран. Само задание: задан массив из k целых чисе . Поменять местами элементы, стоящие на чётных местах, с элементами, стоящими на нечетных. (Для получения случайных чисел с равномерным распределением в интервале [а,b] нужно использовать формулу k=rand() (b-a+1)+a)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.08.2017, 17:38
Ответы с готовыми решениями:

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

Поменять местами соседние элементы массива, стоящие на чётных местах, с элементами, стоящими на нечётных места
Пожалуйста помогите решить задачку... сессия через 2 дня((((( В заданном одномерном массиве поменять местами соседние элементы, стоящие...

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

3
 Аватар для Profi_GMan
4 / 4 / 4
Регистрация: 11.09.2016
Сообщений: 136
Записей в блоге: 5
17.08.2017, 09:59
Я не очень понял, но чтобы поменять местами чётные и нечётные, вот:
C++
1
2
3
4
5
6
7
8
9
10
int main()
{
    int nums[] = {1, 2, 5, 4, 23, 345}; //какой-то массив
    int len = 6; //длина массива
    for(int i = 0; i < len; i += 2) {
        int temp = nums[i];
        nums[i] = nums[i+1];
        nums[i+1] = temp;
    }
}
0
 Аватар для anapshy
531 / 272 / 220
Регистрация: 14.11.2016
Сообщений: 1,052
17.08.2017, 11:10
cvetasik,
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
// ИНКЛЮДЫ
#include <iostream> // cin cout
#include <cstdlib> // srand() rand() system() exit()
#include <ctime> // time()
#include <algorithm> // min() max() swap()
// ПРОТОТИПЫ ФУНКЦИЙ
void PrintArray(const int * const, const std::size_t);
void FillRandomValue(int * const, const std::size_t, const int, const int);
void FillInManually(int * const, const std::size_t);
void SwapEvenAndOdd(int * const, const std::size_t);
// ТОЧКА ВХОДА
int main(void)
{
    std::srand(std::size_t(std::time(NULL)));
    std::size_t k(0U); // U - unsigned
    std::cout << "Enter the size of array: ";
    std::cin >> k;
 
    if (!std::cin.good()) // Если произошла ошибка ввода...
        return EXIT_FAILURE; // return 1;
    
    int *arr = new int[k];
 
    while (true)
    {
        system("cls"); // Очистить консоль
        std::cout << "1. Fill the array manually\n"
            << "2. Fill the array randomly\n"
            << "\nSelection: ";
        
        switch (std::cin.get()) // Ожидается ввода символа
        {
        case '1': // Если это 1...
            {
                FillInManually(arr, k);
                break;
            }
        case '2': // Если это 2...
            {
                int beg_range(0), end_range(0);
                std::cout << "Enter the begin and end of the range...\n"
                    << ".. to fill in randomly: ";
                std::cin >> beg_range >> end_range;
                if (!std::cin.good()) // Если произошла ошибка ввода...
                {
                    std::cin.clear();
                    while (std::cin.get() != '\n');
                    continue; // Возвращаемся в начало while()
                }
                FillRandomValue(arr, k,
                    std::min<int>(beg_range, end_range),
                    std::max<int>(beg_range, end_range));
                break;
            }
            default: // Если это что-либо другое...
            {
                continue; // Возвращаемся в начало while()
            }
        }
 
        system("cls");
        PrintArray(arr, k);
        break;
    }
 
    SwapEvenAndOdd(arr, k);
    PrintArray(arr, k);
 
    delete[] arr;
 
    std::cin.ignore();
    std::cin.get();
    return EXIT_SUCCESS; // return 0;
}
// ОПРЕДЕЛЕНИЕ ФУНКЦИЙ
void PrintArray(const int * const arr, const std::size_t size)
{
    if (size > 0U)
    {
        for (std::size_t i(0U); i < size; i++)
            std::cout << arr[i] << " ";
        std::cout << std::endl;
    }
}
 
void FillRandomValue(int * const arr, const std::size_t size, const int beg_range, const int end_range)
{
    if (size > 0U)
        for (std::size_t i(0U); i < size; i++)
            arr[i] = rand() % (end_range - beg_range + 1) + beg_range;
}
 
void FillInManually(int * const arr, const std::size_t size)
{
    if (size > 0U)
        for (std::size_t i(0U); i < size; i++)
        {
            std::cout << "Enter the value for elem.[" << i + 1 << "/" << size << "] of array: ";
            std::cin >> arr[i];
            if (!std::cin.good())
                return std::exit(EXIT_FAILURE);
        }
}
 
void SwapEvenAndOdd(int * const arr, const std::size_t size)
{
    if (size > 0U)
        for (std::size_t i(0U); i < size; i += 2U)
        {
            if ((i + 1U) < size)
            {
                /// Функция STL библиотеки алгоритмов меняющая местами значения
                std::swap(arr[i], arr[i + 1]);
                /// Обмен местами с помощью 2-х переменных
                /*arr[i] += arr[i + 1U];
                arr[i + 1] = arr[i] - arr[i + 1U];
                arr[i] -= arr[i + 1U];*/
            }
        }
}
0
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
19.08.2017, 00:25
cvetasik, здравствуйте! Выполнил данное задание с использованием дека:

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
#include <bits/stdc++.h>
 
using namespace std;
 
int main()
{
    int N, elem, tmp, k;
    deque<int> x;
    cin >> N;
    for (int i = 0; i < N; i++)
    {
        cin >> elem;
        x.push_back(elem);
    }
    k = 0;
    while (k != N)
    {
        for (int i = 0; i < N - 1; i += 2)
        {
            if (k == i)
            {
                tmp = x.front();
                x.pop_front();
            }
            else if (k == (i + 1))
            {
                x.push_front(tmp);
            }
        }
        cout << x.front() << " ";
        x.pop_front();
        k++;
    }
    cout << endl;
    system("pause");
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.08.2017, 00:25
Помогаю со студенческими работами здесь

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

В заданном одномерном массиве поменять местами соседние элементы, стоящие на четных местах, с элементами, стоящими на нечетных местах
1)В заданном одномерном массиве поменять местами соседние элементы, стоящие на четных местах, с элементами, стоящими на нечетных...

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

В одномерном массиве А(10) поменять местами элементы стоящие на четных и нечетных местах
В одномерном массиве А(10) поменять местами элементы стоящие на четных и нечетных местах,среди элементов расположенных до максимального

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Философия технологии
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(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru