IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> Подпрограммы
Катрин
сообщение 9.02.2006 19:47
Сообщение #1


Гость






Ребят, подскажите, пожалуйста, как решить задачку: Если заданная квадратная целочисленная матрица является треугольной(эл-ты выше главной диагонали = 0) вычислить ее среднее арифметическое, иначе определить, сколько элементов, лежащих выше главной диагонали не равны 0. Заранее спасибо. angel.gif
 К началу страницы 
+ Ответить 
Altair
сообщение 9.02.2006 19:52
Сообщение #2


Ищущий истину
******

Группа: Модераторы
Сообщений: 4 824
Пол: Мужской
Реальное имя: Олег

Репутация: -  45  +


ввод и работа с матрицами

число нулевых элементов выше главной диагонали.

s:=0;
For i:=1 To n Do For j:=i To n Do if a[i,j] = 0 then inc(s);


проверка явл. ли матрица верхнетреугольной..

s:=0;
For i:=1 To n Do
For j:=n-i+1 To n Do s:=s+a[i, j];

Если после прогона s=0 то ДА...

p.s. все взято из той ссылочки что я привел..


--------------------
Помогая друг другу, мы справимся с любыми трудностями!
"Не опускать крылья!" (С)
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
klem4
сообщение 9.02.2006 19:53
Сообщение #3


Perl. Just code it!
******

Группа: Модераторы
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

Репутация: -  44  +


Как работать с разными частями матрицы. FAQ

В следующий раз сначала поиск и FAQ

Altair, опередил ...

Сообщение отредактировано: klem4 - 9.02.2006 19:54


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 10.02.2006 12:25
Сообщение #4


Гость






Если кому понадобится - вот решение за один проход по матрице:
const
n = 5;
amount = ((sqr(n) - n) div 2) + n;

type
mx = array[1 .. n, 1 .. n] of integer;

function get_s(const a: mx; var is_triangle: boolean): real;
var
s: real;
i, j, count: integer;
begin
s := 0; count := 0;
for i := 1 to n do
for j := 1 to n do
if (j > i) then begin
if a[i, j] > 0 then inc(count)
end
else s := s + a[i, j];

is_triangle := (count = 0);
if is_triangle then s := s / amount
else s := count;

get_s := s;
end;

const
a: mx =
(
(1, 0, 0, 0, 0),
(1, 2, 0, 0, 0),
(1, 5, 6, 0, 0),
(1, 0, 5, 0, 0),
(1, 0, 4, 4, 0)
);

var
is_T: boolean;
sum: real;

begin
sum := get_s(a, is_T);
if is_T then writeln('triangle: Average = ', sum:10:5)
else writeln('non-triange: Count = ', sum:3:0);
end.
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 19.06.2025 18:26
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"