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

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

23.04.2017, 21:54. Показов 1250. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru