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

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

09.04.2018, 11:24. Показов 1892. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
четные элементы в начало, нечетные в конец
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int a[100], b[100];
    int n, j = 0, k, i;
    cout << "\nEnter the size of array :";
    cin >> n;
    for (i = 0; i < n; i++)
    {
        a[i] = rand() % 100 - 50;
        cout << a[i] << " ";
    }
    j = 0;
    k = 0;
    for (i = 0; i < n; i++)
    if ((a[i] % 2) == 1){ b[j] = a[i]; j++; }
    for (i = 0; i < n; i++)//эту строку надо исправить 
    if ((a[i] % 2) == 0){ b[j] = a[i-1]; j++; }//эту строку надо исправить
    for (i = 0; i<n; i++)
        cout << b[i] << "\n";
я хз как исправлять хелп ми
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.04.2018, 11:24
Ответы с готовыми решениями:

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

Переместить нулевые элементы в начало массива
#include &lt;iostream&gt; #include&lt;time.h&gt; #include&lt;random&gt; using namespace std; int main() { int min, array,sum=0,f,s,q=0; ...

Элементы массива с нечетными индексами переместить в начало
Даны действительные числа a1 ,…, a20. Получить новый массив, в котором числа исходного массива следуют в данном порядке: а1, а3, а5, …,...

5
 Аватар для anapshy
531 / 272 / 220
Регистрация: 14.11.2016
Сообщений: 1,052
09.04.2018, 12:24
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
// C++11
#include <iostream>
#include <algorithm>
#include <cstdlib>
#include <ctime>
 
const int SIZE{ 40 };
 
int main()
{
    std::srand(unsigned(std::time(0)));
    int arr[SIZE]{};
    for (int i{}; i < SIZE; ++i)
    {
        arr[i] = std::rand() % 10;
    }
    for (int i{}; i < SIZE; ++i)
    {
        std::cout << arr[i] << ' ';
    }
    std::cout << std::endl;
    for (int i{}, j{ SIZE - 1 }; i != j;)
    {
        if (arr[i] % 2)
        {
            std::swap(arr[i], arr[j--]);
            continue;
        }
        ++i;
    }
    for (int i{}; i < SIZE; ++i)
    {
        std::cout << arr[i] << ' ';
    }
    std::cout << std::endl;
}
0
 Аватар для Вадим Тукаев
309 / 290 / 116
Регистрация: 23.01.2018
Сообщений: 933
09.04.2018, 12: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
#include <algorithm>
#include <iostream>
#include <iterator>
#include <random>
 
using namespace std;
 
int main()
{
    mt19937 rng;
    rng.seed(random_device()());
    uniform_int_distribution<mt19937::result_type> dist(-50, 49);
    int n;
    cin >> n;
    vector<int> arr;
    while (n-- > 0) {
        arr.push_back(dist(rng));
    }
    copy(arr.begin(), arr.end(), ostream_iterator<int>(cout, " "));
    cout << endl;
    sort(arr.begin(), arr.end(), [&](const int a, const int b){return a % 2 == 0 && b % 2 != 0;});
    copy(arr.begin(), arr.end(), ostream_iterator<int>(cout, " "));
    cout << endl;
    return 0;
}
0
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
28.04.2018, 16:36
edta, здравствуйте! Вот еще вариант:

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
#include <bits/stdc++.h>
 
    using namespace std;
 
int main() {
    int n;
    cout << "Enter an array size:\n";
    cout << "n = ";
    cin >> n;
    int* arr = new int[n];
    cout << "Enter an array:\n";
    for (int i = 0; i < n; i++) {
        cin >> arr[i];
    }
    for (int i = 0; i < n; i++) {
        for (int j = n - 1; j > i; j--) {
            if ((arr[j-1] % 2) && (!(arr[j] % 2))) {
                swap(arr[j-1], arr[j]);
            }
        }
    }
    cout << "Target array:\n";
    for (int i = 0; i < n; i++) {
        cout << arr[i] << " ";
    }
    delete [] arr;
    system("pause");
    return 0;
}
0
Эксперт С++
1624 / 954 / 782
Регистрация: 06.02.2016
Сообщений: 2,452
Записей в блоге: 31
28.04.2018, 16:43
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
#include <algorithm>
 
int main()
{
    int a[]{1,2,3,4,5,6,7,8,9,10};
    
    std::stable_partition(std::begin(a),std::end(a),[](const int &x){ // или просто partition
        return x%2==0;
    });
    
    for(const auto& x:a)
    {
        std::cout<<x<<" ";
    }
}
0
 Аватар для vlisp
1062 / 983 / 153
Регистрация: 10.08.2015
Сообщений: 5,336
28.04.2018, 17:40
в стиле microsoft

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
#include <iostream>
 
using namespace std;
 
void foo ();
 
 
int main (){ 
   foo();
   return 0;
}
 
void foo (){
    
   const int n = 16;
    
    int a[n], b[n];
 
    int count;
     
    for (int i = 0; i < n; i++)
    {
        a[i] = rand() % 100 - 50;
        cout << a[i] << " ";
    }
    
    cout << endl;
    ////////////////////////////////////////////////////////////////////////////
    for (int i = 0; i < n; i++)
    {
        if (!(a[i]%2)) count++;
    
    }
    
    int counter1 = 0, counter2 = count;
 
    for (int i = 0; i < n; i++)
    {
        if (!(a[i]%2)) 
        b[counter1++] = a[i];
        else
        b[counter2++] = a[i];
 
    }
    /////////////////////////////////////////////////////////////////////////////
    for (int i = 0; i < n; i++)
    {
 
        cout << b[i] << " ";
    }
    
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.04.2018, 17:40
Помогаю со студенческими работами здесь

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

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

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

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

В одномерном массиве все отрицательные элементы переместить в начало массива
в одномерном массиве все отрицательные элементы переместить в начало массива, а остальные - в конец с сохранением порядка следования не...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru