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

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

09.04.2018, 11:24. Показов 1904. Ответов 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
 Аватар для Вадим Тукаев
310 / 291 / 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
1064 / 985 / 153
Регистрация: 10.08.2015
Сообщений: 5,377
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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru