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

Переставить местами четные и нечетные элементы в массиве

01.09.2015, 21:28. Показов 4716. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте уважаемые форумчани!Прошу с задачей мне помочь,нужно переставить местами четные и нечетные элементы в массиве.Напримердо) 1,2,3,4 (после) 2,1,4,3
вот код:
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 *str=new int[11];
int n=1;
void sort(int *num)
{
    int b,i;
    bool c;
    c=true;
    for (i=0;i<=11; ){
        if((num[i]%2!=0)  (num[i+1]%2==0)) \\1
            {
                b=0;
                b=num[i];
                num[i]=num[i+1];
                num[i+1]=b;
                cout<<num[i]<<'_';
                i=i+2;
                c=false;
            }
 
 
        if(c) i++;
    }
}
 
int main()
{
    for(int i=0;i<=11;i++)
    {
        str[i]=n;
        n++;
    }
    sort (str);
    delete [] str;
    system ("pause");
    return 0;
}
Задачку я уже решил,и как оказалось критичная ошибка в строке с комментарием \\1,хотя по логике все верно 1й массива должен быть нечетным,а 2ой четный,если это true,то меняем местами.(Я знаю что в данном коде этот алгоритм смысла не и имеет,т.к числа от 1 до 12).P/S сам для себя я уже ответил на этот вопрос строчкой из книги Шильда,"в действительности не один указатель не может принять массив целиком",хотел бы знать правильно ли я думаю?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.09.2015, 21:28
Ответы с готовыми решениями:

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

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

Найти четные и нечетные элементы одномерного массива и поменять их местами
Найти четные и нечетные элементы одномерного массива и поменять их местами.

4
2549 / 1208 / 358
Регистрация: 30.11.2013
Сообщений: 3,826
01.09.2015, 21:32
C++
1
int *str=new int[11];
Массив с 11 эл. считаем возможные ИНДЕКСЫ:
0 1 2 3 4 5 6 7 8 9 10
Посчитали? 11 штук. Теперь ваш цикл
C++
1
2
 for (i=0;i<=11; ){
        if((num[i]%2!=0)  (num[i+1]%2==0)) \\1
i может быть 11. Уже не подходит и не правильно. Так вы еще +1 делаете. Тоесть обращение по num[12] уже беда.
0
4949 / 2289 / 287
Регистрация: 01.03.2013
Сообщений: 5,984
Записей в блоге: 32
01.09.2015, 21:35
Тема - указатели. В коде - индексы. Пишите нормально на указателях.
0
1 / 0 / 0
Регистрация: 30.06.2015
Сообщений: 46
01.09.2015, 21:49  [ТС]
То что выход за пределы массива это да,а если мне нужно будет подобным образом использовать такую конструкцию то нужно будет использовать указатели?
C++
1
[CPP]if((num[i]%2!=0)  (num[i+1]%2==0))
[/CPP]
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
01.09.2015, 23: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
46
47
48
49
50
51
#include <algorithm>
#include <iostream>
#include <iterator>
/////////////////////////////////////////////////////////////////////////////////////////
template< typename  TT_it >
void    swap_even_and_odd
    (
        TT_it   begin,
        TT_it   end
    )
{
    for (
            auto
            L = begin,
            R = begin + 1;
 
                L != end
            &&  R != end;
 
            ++++L,
            ++++R
        )
    {
        std::iter_swap
            (
                L,
                R
            );
    }
}
/////////////////////////////////////////////////////////////////////////////////////////
int     main()
{
    int     a[]     =   {1, 2, 3, 4, 5};
 
    swap_even_and_odd
        (
            std::begin  (a),
            std::end    (a)
        );
 
    std::copy
        (
            std::begin                  (a),
            std::end                    (a),
            std::ostream_iterator<int>  ( std::cout, " " )
        );
 
    std::cout   <<  std::endl;
    system("pause");
}
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.09.2015, 23:34
Помогаю со студенческими работами здесь

Найти четные и нечетные элементы одномерного массива и поменять их местами
найти четные и нечетные элементы одномерного массива и поменять их местами

Создать двумерный массив и поменять в нем местами четные и нечетные элементы
написать двумерный массив и поменять в нем местами четные и нечетные элементы

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

В одномерном массиве все четные элементы заменить на их квадраты, а нечетные умножить на 2
В одномерном массиве все четные элементы заменить на их квадраты, а нечетные умножить на 2.

Переставить в массиве местами максимальный и минимальный элементы
Вычислить выражение 1*2+2*3*4+3*4*5*6+...+n*(n+1)*(n+2)*...*2n Дан массив X из N целых чисел. Переставить в X местами...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
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 . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru