Форум программистов, компьютерный форум CyberForum.ru

Переставить числа в массиве таким образом, чтобы сначала шли элементы меньше a[b], затем равные a[b], и потом большие - C++

Восстановить пароль Регистрация
 
Макс123456
1 / 1 / 0
Регистрация: 24.01.2014
Сообщений: 17
24.01.2014, 20:32     Переставить числа в массиве таким образом, чтобы сначала шли элементы меньше a[b], затем равные a[b], и потом большие #1
3) Дан массив a[1 ... n] и число b. Переставить числа в массиве таким образом, чтобы сначала шли элементы меньше a[b], затем равные a[b], и потом большие a[b]. Удалить из массива все элементы, равные b и a[b].

прошу помогите, желательно в Visual С++
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.01.2014, 20:32     Переставить числа в массиве таким образом, чтобы сначала шли элементы меньше a[b], затем равные a[b], и потом большие
Посмотрите здесь:

C++ Преобразовать массив таким образом, чтобы сначала располагаись все положительные элементы, а потом-все отлицательные
Преобразовать массив таким образом, чтобы сначала располагались все положительные элементы, а потом все отрицательные C++
Переставить числа в массиве таким образом что бы слева от границы стояли числа меньшие или равные b C++
C++ Преобразовать массив таким образом чтобы сначала располагались все элементы равные нулю а потом остальные
C++ Преобразовать массив таким образом, чтобы сначала располагались все по- ложительные элементы, а потом все остальные
C++ Преобразовать массив таким образом, чтобы сначала располагались четные, а потом нечетные элементы
C++ Превратить массив таким образом, чтобы сначала располагались парные элементы, затем нечетные и нулевые.
C++ Переставить числа в последовательности , что бы сначала шли числа равные первому члену, затем равные второму и тд

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MicM
 Аватар для MicM
820 / 487 / 90
Регистрация: 29.12.2009
Сообщений: 1,097
Завершенные тесты: 1
24.01.2014, 21:29     Переставить числа в массиве таким образом, чтобы сначала шли элементы меньше a[b], затем равные a[b], и потом большие #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
#include <iostream>
#include <ctime>
#include <cstdlib>
 
int main()
{
    srand (time(0));
    const int n = 10;
    int b = 1;
    int i;
    int a[n];
    for (i=0; i<n; i++)
    {
        a[i]=rand()%9+1;
        std::cout <<a[i] <<' ';
    }
    std::cout <<'\n';
    int k = 0,tmp;
    int p = a[b];
    for (i=0; i<n; i++)
        if (a[i]<p)
        {
            tmp = a[i];
            a[i] = a[k];
            a[k] = tmp;
            ++k;
        }
    for (i=k; i<n; i++)
        if (a[i]==p)
        {
            tmp = a[i];
            a[i] = a[k];
            a[k] = tmp;
            ++k;
        }
    for (i=k; i<n; i++)
        if (a[i]>p)
        {
            tmp = a[i];
            a[i] = a[k];
            a[k] = tmp;
            ++k;
        }
    k = 0;
    for (i=0; i<n; i++)
        std::cout <<a[i] <<' ';
    i = 0;
    while (i<n)
    {
        if (a[i]==p || a[i]==b)
        {
           for (int j=i; j<n-1; j++)
               a[j] = a[j+1];
           a[n-k-1] = 0;
           ++k;
        }
        else ++i;
    }
    std::cout <<'\n';
    for (i=0; i<n-k; i++)
        std::cout <<a[i] <<' ';
    std::cout <<'\n';
    return 0;
}
Yandex
Объявления
24.01.2014, 21:29     Переставить числа в массиве таким образом, чтобы сначала шли элементы меньше a[b], затем равные a[b], и потом большие
Ответ Создать тему
Опции темы

Текущее время: 15:41. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru