Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
 Аватар для E87EHUU
1 / 0 / 0
Регистрация: 04.04.2012
Сообщений: 53

Определить позиции несимметричных относительно главной диагонали элементов матрицы порядка NxN

23.05.2012, 08:46. Показов 2057. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Определить позиции несимметричных относительно главной диагонали элементов матрицы порядка NxN
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.05.2012, 08:46
Ответы с готовыми решениями:

Определить позиции несимметричных относительно главной диагонали элементов матрицы порядка NxN
Определить позиции несимметричных относительно главной диагонали элементов матрицы порядка NxN

Для заданной матрицы NxN определить произведение элементов, расположенных на главной диагонали
Для заданной матрицы NxN определить произведение элементов, расположенных на главной диагонали, если * N нечетное, или сумму всех...

Дана квадратная матрица NxN. Зеркально отразить элементы матрицы относительно главной диагонали
Дана квадратная матрица NxN. Зеркально отразить элементы матрицы относительно главной диагонали.

8
призрак
 Аватар для ikki
3266 / 894 / 119
Регистрация: 11.05.2012
Сообщений: 1,702
Записей в блоге: 2
23.05.2012, 09:26
если правильно понял

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

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
sub t()
  dim a, b%(), n%, nn%, i%, j%
  n=[a1].end(xldown).row
  a=[a1].resize(n,n).value
  redim b(1 to (n^2)\2, 2)
  for i=1 to n-1
      for j=i+1 to n
          if a(i,j)<>a(j,i) then
              nn=nn+1
              b(nn,1)=i
              b(nn,2)=j
          end if
      next
  next
 
  columns(n+2).resize(,2).clearcontents
  if nn then
      redim preserve b(1 to nn, 2)
      cells(1,n+2).resize(nn,2).value=b
  end if
end sub
0
 Аватар для E87EHUU
1 / 0 / 0
Регистрация: 04.04.2012
Сообщений: 53
26.05.2012, 18:41  [ТС]
Программа не работает
0
призрак
 Аватар для ikki
3266 / 894 / 119
Регистрация: 11.05.2012
Сообщений: 1,702
Записей в блоге: 2
26.05.2012, 18:49
большое спасибо, что Вы всем об этом сообщили.
в свою очередь, сообщаю Вам:
у меня, в MS Excel 2003, при соблюдении описанных перед программой условий, программа работает.
более того - правильно работает.
(хотя, когда я писал этот код на форум, Excel'я под рукой у меня не было).

увы, мне непонятно, при каких условиях у Вас "программа не работает" - я не телепат, более того - мне неинтересно Вас расспрашивать и переспрашивать, просить и умолять показать файл, в котором "программа не работает" и т.д. и т.п.

расстанемся во взаимонепонимании.
благо - ничем друг друг не обязаны.
1
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18033 / 7736 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
27.05.2012, 01:46
Допишите вначале программы
Visual Basic
1
Option Base 1
или строку №5 запишите в таком виде:
Visual Basic
1
ReDim b(1 To (n ^ 2) \ 2, 1 To 2)
Также закомментируйте строку № 18.

ikki_cf, изменять границы динамического массива можно только у последней размерности.

E87EHUU, обычно всегда принято указывать в каком месте ошибка и какая именно, благо не в первый раз на форуме.
0
призрак
 Аватар для ikki
3266 / 894 / 119
Регистрация: 11.05.2012
Сообщений: 1,702
Записей в блоге: 2
27.05.2012, 02:35
Лучший ответ Сообщение было отмечено как решение

Решение

Цитата Сообщение от Diskretor Посмотреть сообщение
Visual Basic
1
Option Base 1
...
ikki_cf, изменять границы динамического массива можно только у последней размерности.
ай!!!
простите идиёта!
0
 Аватар для E87EHUU
1 / 0 / 0
Регистрация: 04.04.2012
Сообщений: 53
30.05.2012, 09:21  [ТС]
Возникает ошибка Runtime error 6 over flow
0
Эксперт WindowsАвтор FAQ
 Аватар для Dragokas
18033 / 7736 / 892
Регистрация: 25.12.2011
Сообщений: 11,502
Записей в блоге: 16
30.05.2012, 15:08
Цитата Сообщение от ikki_cf Посмотреть сообщение
n=[a1].end(xldown).row
при n%, а офис видимо =>2007, да массив либо не заполнен, либо не там, либо он огромен.

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Option Base 1
 
Sub t()
  Dim a, b%(), n&, nn&, i&, j&
  n = [a1].End(xlDown).Row
  a = [a1].Resize(n, n).Value
  ReDim b(1 To (n ^ 2) \ 2, 2)
  For i = 1 To n - 1
      For j = i + 1 To n
          If a(i, j) <> a(j, i) Then
              nn = nn + 1
              b(nn, 1) = i
              b(nn, 2) = j
          End If
      Next
  Next
  
  Columns(n + 2).Resize(, 2).ClearContents
  If nn Then
      Cells(1, n + 2).Resize(nn, 2).Value = b
  End If
End Sub
Вложения
Тип файла: xls Matr_Dif.xls (23.5 Кб, 10 просмотров)
1
30.05.2012, 15:19

Не по теме:

Цитата Сообщение от Diskretor Посмотреть сообщение
при n%, а офис видимо =>2007,
даже при всем при этом, столбцов на листе никак не больше 32767, а матрица - квадратная
Цитата Сообщение от Diskretor Посмотреть сообщение
да массив либо не заполнен, либо не там, либо он огромен.
ну правильно - для чего читать вводные перед макросом, да ещё и придерживаться их? :D

Diskretor, в любом случае спасибо. :drink:

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.05.2012, 15:19
Помогаю со студенческими работами здесь

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

Определить, является ли матрица N-ого порядка симметричной относительно главной диагонали
Определить, является ли матрица N-ого порядка симметричной (относительно главной диагонали).

Определить, является ли квадратная матрица 10-го порядка симметричной относительно главной диагонали.
Определить, является ли квадратная матрица 10-го порядка симметричной относительно главной диагонали. Напишите если не трудно...

Определить, является ли целая квадратная матрица порядка n симметричной (относительно главной диагонали)
Помогите пожалуйста. В строке if(array1 == array1) выдаёт ошибку идентификатор i (и j) не определен. Почему так происходит? #include...

Определить, является ли целая квадратная матрица порядка n симметричной (относительно главной диагонали)
Помогите пожалуйста, срочно нужно


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru