0 / 0 / 0
Регистрация: 24.02.2018
Сообщений: 42
1

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

09.04.2018, 11:24. Показов 1403. Ответов 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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
09.04.2018, 11:24
Ответы с готовыми решениями:

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

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

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

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

5
279 / 251 / 209
Регистрация: 14.11.2016
Сообщений: 948
09.04.2018, 12:24 2
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
303 / 284 / 116
Регистрация: 23.01.2018
Сообщений: 933
09.04.2018, 12:34 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
#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
1503 / 967 / 811
Регистрация: 30.04.2016
Сообщений: 3,334
28.04.2018, 16:36 4
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
Эксперт С++
1623 / 953 / 782
Регистрация: 06.02.2016
Сообщений: 2,449
Записей в блоге: 30
28.04.2018, 16:43 5
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
606 / 839 / 142
Регистрация: 10.08.2015
Сообщений: 4,238
28.04.2018, 17:40 6
в стиле 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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.04.2018, 17:40
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru