Форум программистов, компьютерный форум, киберфорум
Visual Basic
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
Заблокирован

Сортировка двумерного массива по чётности позиций

23.04.2017, 21:54. Показов 1271. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Прошу помощи. Не знаю алгоритма перестановок столбцов по чётности. Как переставлять, не вручную же, если столбцов несколько десятков?
Условия. Дана целочисленная прямоугольная матрица. Преобразовать массив таким образом, чтобы в первой его половине располагались элементы, стоявшие в четных позициях, а во второй половине — элементы, стоявшие в нечетных позициях.
У меня матрица 6*6 поэтому легко поменял местами нужные столбцы почти вручную.
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Sub ЧётНечётСтолбцы()
Dim i%, j%, a(), b() As Integer
 
'--------------------
ActiveSheet.UsedRange.EntireRow.Delete
Cells.Clear
[A1] = -9:  [B1] = -8:  [C1] = -4:  [D1] = -8:  [E1] = -10: [F1] = -5
[A2] = 0:   [B2] = 3:   [C2] = 0:   [D2] = 6:   [E2] = -9: [F2] = 2
[A3] = -7:  [B3] = 3:   [C3] = -1:  [D3] = -3:  [E3] = -8: [F3] = 9
[A4] = 4:   [B4] = 8:   [C4] = 0:   [D4] = -9:  [E4] = 5: [F4] = 4
[A5] = -2:  [B5] = -1:  [C5] = -1:  [D5] = -6:  [E5] = -4: [F5] = -1
[A6] = -9:  [B6] = 1:   [C6] = -7:  [D6] = 8:   [E6] = -9: [F6] = 7
a = Sheets(1).[A1].CurrentRegion.Value
    Sheets(1).[a8].Resize(6, 5) = a
Range("A8:A13").Value = Range("D1:D6").Value
Range("D8:D13").Value = Range("A1:A6").Value
Range("C8:C13").Value = Range("F1:F6").Value
Range("F8:F13").Value = Range("C1:C6").Value
    
End Sub
Миниатюры
Сортировка двумерного массива по чётности позиций  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.04.2017, 21:54
Ответы с готовыми решениями:

Сортировка двумерного массива
Добрый день! искала-искала, про двумерные массивы не нашла :( может есть какой-то стандартный метод (типа sort) чтобы отсортировать...

Сортировка двумерного массива
"Дан двумерный массив. Нужно найти четные элементы массива (по i , j и значению) ниже главной диагонали четвертой строки и нечетные...

Сортировка двумерного массива, срочно
Дан массив 6*6 нужно получить результирующий массив, где каждая строка упорядочена по возврастанию.... и также упорядочить эту задачу по...

2
Регистрация: 23.10.2013
Сообщений: 5,076
Записей в блоге: 8
24.04.2017, 08:53
MyExcel_17
Программа написана для четного числа столбцов
(для нечетного числа изменения невелики)

Visual Basic
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
CLS
RANDOMIZE TIMER
CONST n = 6
REDIM x(n, n) AS LONG
REDIM z(n, n) AS LONG
 
FOR i = 1 TO n
FOR j = 1 TO n
   x(i, j) = 18 * RND - 9
   PRINT x(i, j);
NEXT: PRINT
NEXT: PRINT
 
FOR j = 1 TO n
FOR i = 1 TO n
   IF j MOD 2 THEN
      z(i, (j + n + 1) / 2) = x(i, j)
   ELSE
      z(i, j / 2) = x(i, j)
   END IF
NEXT i, j
 
FOR i = 1 TO n
FOR j = 1 TO n
   PRINT z(i, j);
NEXT: PRINT
NEXT
0
Заблокирован
24.04.2017, 11:40  [ТС]
Цитата Сообщение от echs Посмотреть сообщение
Программа написана для четного числа столбцов
echs, спасибо. Всё отлично сортируется. Картинка ниже.
Внес маленькие изменения в код для VBA (Эксель).
Visual Basic
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
Sub echsSort()
Randomize Timer
Const n = 6
ReDim x(n, n) As Long
ReDim Z(n, n) As Long
 
For i = 1 To n
  For j = 1 To n
   x(i, j) = 18 * Rnd - 9
   Cells(i, j) = x(i, j)
   Z(i, j) = x(i, j)
  Next j
Next i
 
For j = 1 To n
  For i = 1 To n
   If j Mod 2 Then
      Z(i, (j + n + 1) / 2) = x(i, j)
   Else
      Z(i, j / 2) = x(i, j)
   End If
Next i, j
 
For i = 1 To n
  For j = 1 To n
    Cells(i + 7, j) = Z(i, j)
  Next j
Next i
End Sub
Миниатюры
Сортировка двумерного массива по чётности позиций  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.04.2017, 11:40
Помогаю со студенческими работами здесь

Сортировка элементов столбцов двумерного массива
А. Составить процедуру сортировки по убыванию значений элементов массива А(М) (М - заданное число). В. Используя процедуру рассортировать...

Сдвинуть элементы двумерного массива на k позиций влево
Немножко не умею пользоваться динамическими массивами. Из-за этого кажется сделал глупые ошибки в программе Суть программы: Сдвинуть...

Сортировка массива и вывод старых позиций
Здравствуйте! Возник вопрос. Необходимо вывести отсортированный массив со СТАРЫМИ позициями в массиве. Как можно сохранять эти...

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

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru