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

Сортировка трехмерного массива (куба)

26.11.2017, 17:32. Показов 2342. Ответов 18

Студворк — интернет-сервис помощи студентам
Добрый день! Мне надо написать программу, которая будет создавать трехмерный массив (куб) и сортировать его значения. После чего эти значения заполняются в куб от любого его угла (на выбор пользователя).

У меня создается куб. Потом его значения я записываю в одномерный массив, и сортирую его. Потом я хочу перевести отсортированный одномерный массив в трехмерный (куб), однако на выходе у меня идет неправильное заполнение.. В чем ошибка? Спасибо!

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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include <iostream>
#include <stdlib.h>
using namespace std;
 
int main()
{ 
    srand(time(NULL));
    int x = 3, y = 3, z = 3, q = 27, counter = 0;
    int a[x][y][z];
  
  //заполнение массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
a[i][j][k] = rand() % 10;
}
}
}  
//вывод массива
printf("Заполнение куба:\n");
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
printf("%d ", a[i][j][k]);
}
printf("\n");
}
printf("\n");
}
 
  
  printf("Размер одномерного массива: %d \n", x*y*z);
  short * arr = new short [x * y * z];
  for (int i = 0; i < x; ++i)
    for (int j = 0; j < y; ++j)
     for(int k = 0; k < z; ++k)
      arr[counter++] = a[i][j][k];
      
      
  printf("Одномерный массив:\n");
  for (int q = 0; q < x * y * z; ++q)
     printf("%d ", arr[q]);
  //delete [] arr;
  printf("\n");
   
   
    //Отсортируем массив по убыванию 
    for(int i = 1; i < q; ++i)
    {
        for(int r = 0; r < q-i; r++)
        {
            if(arr[r] < arr[r+1])
            {
                // Обмен местами
                int temp = arr[r];
                arr[r] = arr[r+1];
                arr[r+1] = temp;
            }
        }
    } 
    //Выведем отсортированный массив 
    printf("Отсортированный массив: \n");
    for(int i = 0; i < q; ++i)
    {
        printf("%d ", arr[i]);
    }
    printf("\n");
 
 
  //заполнение массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
   
a[i][j][k] = arr[i];
 
}
}
}  
  
 
//вывод массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
printf("%d ", a[i][j][k]);
}
printf("\n");
}
printf("\n");
}
 
system("pause");
  
  return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.11.2017, 17:32
Ответы с готовыми решениями:

Сортировка трехмерного массива
нужно отсортировать трехмерный массив. перевожу его в одномерный и хочу отсортировать его, но строка не сортируется, а выводится тот же...

Сортировка трехмерного массива
Не могу понять, как (за приемлемое время - не более 300мс) отсортировать трехмерный массив на 500^3 элементов (куб). Сортировка должна...

Сортировка трехмерного массива
Выполнить сортировку трехмерного массива методом вставки, пызырька!

18
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 20:00
Сделайте аналогично 37 строке, используя вспомогательную переменную для индексации одномерного массива.
0
 Аватар для QuakerRUS
1469 / 1010 / 456
Регистрация: 30.10.2017
Сообщений: 2,799
26.11.2017, 20:33
Сортировка трехмерного массива
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 20:38  [ТС]
likehood, что-то я не очень понял, не могли бы участок кода написать?

то есть что-то типа этого написать для второго вывода трехмерного массива? Вроде, там то же самое, и используются другие индексы (arr[counter++] = a[i][j][k]; )
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 21:17
Цитата Сообщение от kindastan Посмотреть сообщение
что-то я не очень понял, не могли бы участок кода написать?
C++
1
a[i][j][k] = arr[counter++]
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 21:20  [ТС]
likehood, исправил, однако теперь вообще он в массиве нули показывает :с
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
  //заполнение массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
   
   a[i][j][k] = arr[counter++];
 
 
}
}
}  
  
 
//вывод массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
printf("%d ", arr[counter++]);
}
printf("\n");
}
printf("\n");
}
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 22:14
Только теперь вы выводите одномерный массив, а не трёхмерный.

Кроме того, вы не забыли обнулить counter в начале циклов?
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 22:21  [ТС]
likehood, почему вывожу одномерный? как раз циклами (строчки 14-23) вывожу куб (индексы i,j,k).

Вот на скрине показал, чем компилятор заполняет куб из одномерной строчки. Если counter обнулять и использовать, то только нули там
Миниатюры
Сортировка трехмерного массива (куба)  
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 22:41
Покажите полный код.
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 22:50  [ТС]
likehood, он в самой теме есть, я больше ничего не менял
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 22:59
Цитата Сообщение от kindastan Посмотреть сообщение
я больше ничего не менял
То есть то что я писал до этого вы не сделали?
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 23:00  [ТС]
likehood, я заменял, но все равно неправильно куб заполнялся
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 23:04
Цитата Сообщение от kindastan Посмотреть сообщение
я заменял, но все равно неправильно куб заполнялся
Цитата Сообщение от kindastan Посмотреть сообщение
Если counter обнулять и использовать, то только нули там
Покажите код.
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 23:05  [ТС]
likehood,
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include <iostream>
#include <stdlib.h>
using namespace std;
 
int main()
{ 
    srand(time(NULL));
    int x = 3, y = 3, z = 3, q = 27, counter = 0;
    int a[x][y][z];
  
  //заполнение массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
a[i][j][k] = rand() % 10;
}
}
}  
//вывод массива
printf("Заполнение куба:\n");
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
printf("%d ", a[i][j][k]);
}
printf("\n");
}
printf("\n");
}
 
  
  printf("Размер одномерного массива: %d \n", x*y*z);
  short * arr = new short [x * y * z];
  for (int i = 0; i < x; ++i)
    for (int j = 0; j < y; ++j)
     for(int k = 0; k < z; ++k)
      arr[counter++] = a[i][j][k];
      
      
  printf("Одномерный массив:\n");
  for (int q = 0; q < x * y * z; ++q)
     printf("%d ", arr[q]);
  //delete [] arr;
  printf("\n");
   
   
    //Отсортируем массив по убыванию 
    for(int i = 1; i < q; ++i)
    {
        for(int r = 0; r < q-i; r++)
        {
            if(arr[r] < arr[r+1])
            {
                // Обмен местами
                int temp = arr[r];
                arr[r] = arr[r+1];
                arr[r+1] = temp;
            }
        }
    } 
    //Выведем отсортированный массив 
    printf("Отсортированный массив: \n");
    for(int i = 0; i < q; ++i)
    {
        printf("%d ", arr[i]);
    }
    printf("\n");
 
 
  //заполнение массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
   
a[i][j][k] = arr[i];
 
}
}
}  
  
 
//вывод массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
printf("%d ", a[i][j][k]);
}
printf("\n");
}
printf("\n");
}
 
system("pause");
  
  return 0;
}
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 23:09
Цитата Сообщение от kindastan Посмотреть сообщение
однако на выходе у меня идет неправильное заполнение
Мои рекомендации:
Цитата Сообщение от likehood Посмотреть сообщение
a[i][j][k] = arr[counter++]
Цитата Сообщение от likehood Посмотреть сообщение
вы не забыли обнулить counter в начале циклов?
Где всё это???
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 23:11  [ТС]
likehood, я исправлял, но неправильно заполняет
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include <iostream>
#include <stdlib.h>
using namespace std;
 
int main()
{ 
    srand(time(NULL));
    int x = 3, y = 3, z = 3, q = 27, counter = 0;
    int a[x][y][z];
  
  //заполнение массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
a[i][j][k] = rand() % 10;
}
}
}  
//вывод массива
printf("Заполнение куба:\n");
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
printf("%d ", a[i][j][k]);
}
printf("\n");
}
printf("\n");
}
 
  
  printf("Размер одномерного массива: %d \n", x*y*z);
  short * arr = new short [x * y * z];
  for (int i = 0; i < x; ++i)
    for (int j = 0; j < y; ++j)
     for(int k = 0; k < z; ++k)
      arr[counter++] = a[i][j][k];
      
      
  printf("Одномерный массив:\n");
  for (int q = 0; q < x * y * z; ++q)
     printf("%d ", arr[q]);
  //delete [] arr;
  printf("\n");
   
   
    //Отсортируем массив по убыванию 
    for(int i = 1; i < q; ++i)
    {
        for(int r = 0; r < q-i; r++)
        {
            if(arr[r] < arr[r+1])
            {
                // Обмен местами
                int temp = arr[r];
                arr[r] = arr[r+1];
                arr[r+1] = temp;
            }
        }
    } 
    //Выведем отсортированный массив 
    printf("Отсортированный массив: \n");
    for(int i = 0; i < q; ++i)
    {
        printf("%d ", arr[i]);
    }
    printf("\n");
 
 
 
  //заполнение массива
  arr[counter++] = 0;
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
   
a[i][j][k] = arr[counter++];
 
}
}
}  
  
 
//вывод массива
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
for (int k = 0; k < z; k++) {
printf("%d ", arr[counter++]);
}
printf("\n");
}
printf("\n");
}
 
system("pause");
  
  return 0;
}
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
26.11.2017, 23:18
Цитата Сообщение от kindastan Посмотреть сообщение
я исправлял
Видимо неправильно, раз не работает.
Цитата Сообщение от kindastan Посмотреть сообщение
, но неправильно заполняет
Как и исходный код.

Добавлено через 1 минуту
Строки 71-93, проверьте
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
//заполнение массива
counter = 0;
 
for (int i = 0; i < x; i++)
{
    for (int j = 0; j < y; j++)
    {
        for (int k = 0; k < z; k++)
        {
 
            a[i][j][k] = arr[counter++];
 
        }
    }
}
 
 
//вывод массива
for (int i = 0; i < x; i++)
{
    for (int j = 0; j < y; j++)
    {
        for (int k = 0; k < z; k++)
        {
            printf("%d ", a[i][j][k]);
        }
        printf("\n");
    }
    printf("\n");
}
0
0 / 0 / 0
Регистрация: 26.11.2017
Сообщений: 69
26.11.2017, 23:37  [ТС]
likehood, СПАСИБО ОГРОМНОЕ!

Добавлено через 15 минут
likehood, а не подскажите насчет сортировки от угла... то есть так просто куб заполняется снизу вверх. А какой примерно алгоритм нужен, чтобы от угла заполнялся?
0
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
27.11.2017, 00:08
Цитата Сообщение от kindastan Посмотреть сообщение
то есть так просто куб заполняется снизу вверх
... начиная с угла с координатами a[0][0][0]. Сортируем мы в любом случае одномерный массив, весь вопрос в последующем заполнении.

Чтобы заполнить с другого угла, нужно поменять направление изменения индексов. Например:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
//заполнение массива
counter = 0;
for (int i = 0; i < x; i++)
{
    for (int j = y-1; j >=0; j--) // << стартуем с угла a[0][y-1][0]
    {
        for (int k = 0; k < z; k++)
        {
 
            a[i][j][k] = arr[counter++];
 
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.11.2017, 00:08
Помогаю со студенческими работами здесь

Выделить память для трехмерного массива и изменить индексы начального элемента массива
Выделить память для трехмерного массива а. Изменить индексы начального элемента массива на . Протестировать программу

Заполнение трехмерного массива
Помогите с заполнением трехмерного массива, мне нужно чтобы он заполнился по порядку от 0 до 60. #include &lt;stdio.h&gt; #include...

Заполнение трехмерного массива
Есть программа которая считает расстояние скоростного пути.. и если машина находится близко к впереди идущей машине, то программа нам об...

Заполнить диагональ трехмерного массива
#include &lt;iostream&gt; using namespace std; class Arrtridimensional {//Объявили класс public: static const int x = 5, y = 5, z = 5; ...

Сумма элементов трехмерного массива
Имеется трехмерный массив из 3-ех слоев по 3Х3 элемента в каждом слое, в первом слое все элементы единицы, во втором слое - двойки, в...


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

Или воспользуйтесь поиском по форуму:
19
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru