Задача: Нахождение ранга матрицы! |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
Задача: Нахождение ранга матрицы! |
BDS |
Сообщение
#1
|
Новичок Группа: Пользователи Сообщений: 17 Репутация: 0 |
Кто-нибудь знает, как написать алгоритм нахождения ранга матрицы?
Если сможете, помогите! ??? |
BDS |
Сообщение
#2
|
Новичок Группа: Пользователи Сообщений: 17 Репутация: 0 |
А еще нашел модуль для работы с матрицами, там тоже это есть, но не знаю как оттуда вытащить. ???
Это только функция вычисления ранга, а сам модуль 600 с лишним строк и почти 13Кб (в zip.-е ок.3.5Кб), так что если нужно могу или сюда положить, или на e-mail кому-нибудь прислать. Код function Matr.Rg:byte; {------- Вычисление ранга матрицы } var l,j,k,min,rang:byte; sz:extended; tmp:Mp; begin min:=m; new(tmp,Init(n,m)); Move(ar^,tmp^.ar^,n*m*SizeOf(extended)); if n<m then begin min:=n; SetM(tmp,tmp^.T) end; with tmp^ do begin for k:=1 to min do for l:=1 to n do if l<>k then begin if e(k,k)^=0 then continue else sz:=e(l,k)^/e(k,k)^; for j:=1 to m do e(l,j)^:=e(l,j)^-sz*e(k,j)^ end; rang:=0; for l:=1 to min do if e(l,l)^<>0 then inc(rang); end; Dispose(tmp,Done); Rg:=rang end; |
Текстовая версия | 25.04.2024 20:17 |