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

Массив: Преобразовать массив таким образом, чтобы сначала располагались все элементы > 0, а потом < 0...

02.10.2019, 14:27. Показов 641. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Преобразовать одномерный целочисленный массив таким образом, чтобы сначала располагались все положиТельные элементы, а потом-отрицательные(0-положительное)
!!!!!! Нужно в главно функции вводить одномерный массив, а в названной функции передать по указателю-массив, а его размерность по ссылке; из главной функции вызывается названная функция и выполняет преобразование !!!!!!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
02.10.2019, 14:27
Ответы с готовыми решениями:

Преобразовать массив таким образом чтобы сначала располагались все элементы равные нулю а потом остальные
#include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; using namespace std; int...

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

Преобразовать массив таким образом, чтобы сначала располагались все положительные элементы, а потом - все остальные
Помогите, пожалуйста. как составить код в с++. Дан целочисленный массив размера N. Преобразовать...

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

2
863 / 513 / 215
Регистрация: 19.01.2019
Сообщений: 1,216
03.10.2019, 00:32 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
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
#include <iostream>
 
template<typename T>
void quickSort(T* lhs, T* rhs, int(*pred)(const T*, const T*)) {
    if (rhs - lhs <= 1) {
        return;
    }
    T pivot = *(lhs + (rhs - lhs) / 2);
    T* l = lhs;
    T* r = rhs - 1;
    while (l <= r) {
        while (pred(l, &pivot) == -1) {
            ++l;
        }
        while (pred(r, &pivot) == 1) {
            --r;
        }
        if (l <= r) {
            std::iter_swap(l, r);
            ++l;
            --r;
        }
    };
    if (lhs < r) {
        quickSort(lhs, r + 1, pred);
    }
    if (l < rhs) {
        quickSort(l, rhs, pred);
    }
}
 
template <typename T>
void sortPosFirst(T* arr, size_t& size) {
    quickSort<T>(arr, arr + size, [](const T* first, const T* second)->int {
        if (*first == *second) {
            return 0;
        }
        if (*first >= 0) {
            if (*second < 0) {
                return -1;
            }
            return *first > *second ? 1 : -1;
        }
        if (*second >= 0) {
            return 1;
        }
        return *first > *second ? 1 : -1;
    });
}
 
 
int main()
{
    size_t size;
    std::cout << "Array size: ";
    std::cin >> size;
    int* arr = new int[size];
    for (int* it = arr; it != arr + size; ++it) {
        *it = rand() % 10 - 5;
        std::cout << *it << ' ';
    }
    std::cout << "\n\n";
 
    sortPosFirst(arr, size);
 
    for (int* it = arr; it != arr + size; ++it) {
        std::cout << *it << ' ';
    }
    std::cout << '\n';
 
    delete[] arr;
    return 0;
}
0
7437 / 5029 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
03.10.2019, 00:58 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
#include <iostream>
using namespace std;
 
void ShiftPos (int *a, int &n)
{
    int k=0;
    for (int i = 0; i < n; i++)
        if (a[i]>=0)
        {
            for (int j = i; j > k; j--)
            swap(a[j],a[j-1]);
            k++;
        }
}
 
int main()
{
    int n;    
    cout << "n="; cin >>n;
    
    int*a = new int[n];
 
    cout << "Enter " << n << " elements:\n";
    for (int i = 0; i < n; i++)
        cin >> a[i];    
        cout << "\n"; 
        
    ShiftPos(a,n);        
        
    for (int i = 0; i < n; i++)
      cout << a[i]<< " ";
      cout << "\n";
 
     delete[]a;
system("pause");
return 0;
}
0
03.10.2019, 00:58
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.10.2019, 00:58
Помогаю со студенческими работами здесь

Преобразовать массив таким образом, чтобы сначала располагались все по- ложительные элементы, а потом все остальные
#include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; #include &lt;cmath&gt; using namespace...

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

Преобразовать массив таким образом, чтобы сначала располагались все по- ложительные элементы, а потом все остальные.как доработать?
#include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; #include &lt;cmath&gt; using namespace...

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru