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

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

26.05.2022, 14:07. Показов 755. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В массиве A(N) каждый элемент равен 1, 2 или 3. Переставить элементы массива так, чтобы сначала располагались все нули, затем все двойки и, наконец, все единицы (дополнительного массива не заводить).
С возможностью задавать масив
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.05.2022, 14:07
Ответы с готовыми решениями:

Переставить элементы массива так, чтобы сначала располагались все нули, затем все двойки и, наконец, все единицы
Добрый день ! У меня к вам просьба. Помогите решить задачу по с++ начинающему чайнику. :wall: Задача. В массиве A(N) каждый...

Переставить элементы массива так, чтобы сначала располагались все нули, затем все единицы, а затем все пятерки
1) В массиве X(1:n) каждый элемент равен 0, 1 или 5. Переставить элементы массива так, чтобы сначала располагались все нули, затем все...

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

7
 Аватар для Nishen
1359 / 857 / 366
Регистрация: 26.02.2015
Сообщений: 3,824
26.05.2022, 14:18
Тебе его отсортировать нужно по возрастанию. Используй std::sort.
0
1 / 1 / 0
Регистрация: 17.01.2022
Сообщений: 79
26.05.2022, 14:20  [ТС]
Цитата Сообщение от Nishen Посмотреть сообщение
Тебе его отсортировать нужно по возрастанию. Используй std::sort.
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
#include <iostream>
#include <iomanip>
using namespace std;
 
void swap(int* massiv, int index_one, int index_two)
{
    int temp = massiv[index_one];
    massiv[index_one] = massiv[index_two];
    massiv[index_two] = temp;
}
 
void func(int* a, const int size)
{
    int index = 1;
    for (int i = 1; i < size; i++)
    {
        if (a[i] == 1)
        {
            swap(a, i, index);
            ++index;
        }
    }
    for (int i = index; i < size; i++)
    {
        if (a[i] == 2)
        {
            swap(a, i, index);
            ++index;
        }
    }
}
 
int main()
{
    const int N = 9;
    int a[N]= { 1,2,1,2,3,3,3,1,2 };
    cout << endl;
    func(a, N);
    for (int i = 0; i < N; i++)
        cout << setw(3) << a[i];
    cout << "Peretvor mas:"<< endl;
    return 0;
}
Вот код который есть. Не могу понять как сделать вывод начальных чисел. А после переделаных Ошибку дает
0
 Аватар для Nishen
1359 / 857 / 366
Регистрация: 26.02.2015
Сообщений: 3,824
26.05.2022, 14:38
Лучший ответ Сообщение было отмечено Kipeshnoy как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <algorithm>
#include <iostream>
 
 
 
int main()
{
    const std::size_t SIZE = 9;
    int arr[SIZE] = { 1, 2, 1, 2, 3, 3, 3, 1, 2 };
    std::sort(std::begin(arr), std::end(arr));
 
    for (auto el : arr) {
        std::cout << el << '\n';
    }
 
    return 0;
}
1
1 / 1 / 0
Регистрация: 17.01.2022
Сообщений: 79
26.05.2022, 14:41  [ТС]
Цитата Сообщение от Nishen Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <algorithm>
#include <iostream>
int main()
{
    const std::size_t SIZE = 9;
    int arr[SIZE] = { 1, 2, 1, 2, 3, 3, 3, 1, 2 };
    std::sort(std::begin(arr), std::end(arr));
for (auto el : arr) {
        std::cout << el << '\n';
    }
return 0;
}
Про это я понял. Но не знаю как организовать что-бы в консоль выводились начальные значение то-есть: 1,2,1,2,3,3,3,1,2
А после этого выводилось уже отсортированный масив
0
 Аватар для Nishen
1359 / 857 / 366
Регистрация: 26.02.2015
Сообщений: 3,824
26.05.2022, 14:51
Перед сортировкой сделай цикл еще раз с выводом в консоль. Потом сортируй. Потом выводи еще раз.
0
1 / 1 / 0
Регистрация: 17.01.2022
Сообщений: 79
26.05.2022, 15:15  [ТС]
Цитата Сообщение от Nishen Посмотреть сообщение
Перед сортировкой сделай цикл еще раз с выводом в консоль. Потом сортируй. Потом выводи еще раз.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <algorithm>
#include <iostream>
using namespace std;
#pragma warning (disable : 4996)
 
 
int main()
{
    const size_t SIZE = 6;
    int arr[SIZE] = { 1, 2, 1, 3,2, 3};
    for (auto ol : arr) { cout << "po4at: " << ol; }
    sort(begin(arr),end(arr));
 
    for (auto el : arr) {
        cout << "Pererob: ";
        cout << el;
            
    }
 
    return 0;
}
Как сделать да-бы оно не спамило и вывелось в строку, а не в столбец?
Миниатюры
Переставить элементы массива так, чтобы сначала располагались все еденицы, затем все двойки и, наконец, все тройки  
0
848 / 651 / 323
Регистрация: 24.02.2017
Сообщений: 2,297
26.05.2022, 15:16
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
using namespace std;
 
int main(){
 
      int n[9]={ 1,2,1,2,3,3,3,1,2 },n1=0,n2=0,n3=0;
 
      for(int i=0;i<9;i++){
           cout<<n[i]<<" ";
           n[i]==1 ? n1++ :(n[i]==2 ? n2++ : n3++);
      }
      cout<<"\n\n";
      int j=0;
      while(n1--)n[j++]=1;
      while(n2--)n[j++]=2;
      while(n3--)n[j++]=3;
      for(int i=0;i<9;i++)
           cout<<n[i]<<" ";
      return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.05.2022, 15:16
Помогаю со студенческими работами здесь

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

Переставить элементы массива так, чтобы сначала располагались все 0, затем все 1, а затем все 5
Решите задачу,не могу решить сам.В массиве X(1:n) каждый элемент равен 0, 1 или 5. Переставить элементы массива так, чтобы сначала...

Переставить элементы массива так, чтобы сначала располагались все единицы, затем все двойки и, наконец, все нули
Ребят помогите пожалуйста В массив x(N) каждый элемент равен 0,1 или 2. Приставить элементы массива так, чтобы сначала располагались...

Массив: Переставить элементы массива так, чтобы сначала располагались все единицы, затем все двойки, наконец, все нули.
В массиве X(N) каждый элемент равен 0,1 или 2. Переставить элементы массива так, чтобы сначала располагались все единицы, затем все двойки,...

Переставить элементы массива так, чтобы располагались все нули, затем все единицы, и, наконец, все двойки
Помогите пожалуйста решить задачу: В массиве х(12) каждый элемент равен 0, 1 или 2. Переставить элементы массива так, чтобы располагались...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru