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

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

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

 
 Ответить  Открыть новую тему 
> Элементы матрицы расположенные по периметру
Lidroot
сообщение 31.10.2005 17:44
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 18
Пол: Мужской

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


Вообщем задача: Найти некоторые элементы(не вожно какие!) среди элементов матрицы, расположенных по периметру.
Я думаю это сделать гдето так:
Код

for i:=1 to 6 do
for j:=1 to 6 do
begin
if (i:=1) and (k=0) then
begin
c(count):=a[i,j];
k:=1;
inc(count);
end;
if (i:=6) and (k=0) then
begin
c(count):=a[i,j];
k:=1;
inc(count);
end;
if (j:=1) and (k=0) then
begin
c(count):=a[i,j];
k:=1;
inc(count);
end;
if (j:=6) and (k=0) then
begin
c(count):=a[i,j];
k:=1;
inc(count);
end;
end;

но мне кажется это громоздким. Может что нить еще можно сделать?

Сообщение отредактировано: Lidroot - 31.10.2005 17:45
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
APAL
сообщение 31.10.2005 18:10
Сообщение #2


Смотрю...
*****

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

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


Так как
Цитата
не вожно какие!
:
For i:=1 to 6 do Write(a[i,1],#10#13,a[i,6],#10#13,a[1,i],#10#13,a[6,i],#10#13);


Интересно, что дает конструкция:
Код
c(count):=a[i,j];
k:=1;

?


--------------------
Если что-то не делает того, что вы запланировали ему делать - это еще не означает, что оно бесполезно.
--------------------
Прежде, чем задать вопрос - Правила :: FAQ :: Поиск
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 31.10.2005 18:14
Сообщение #3


Гость






To: APAL
А дублироваться элементы не будут? wink.gif

Я бы сделал так:
  for i := 1 to n do
for j := 1 to n do
if (i in [1, n]) or (j in [1, n]) then begin
write(a[i, j]:5);
end;

 К началу страницы 
+ Ответить 
APAL
сообщение 31.10.2005 18:20
Сообщение #4


Смотрю...
*****

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

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


Конечно будут! Угловые.

Но именно так я понял условия:
Цитата
не вожно какие!


--------------------
Если что-то не делает того, что вы запланировали ему делать - это еще не означает, что оно бесполезно.
--------------------
Прежде, чем задать вопрос - Правила :: FAQ :: Поиск
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Lidroot
сообщение 31.10.2005 22:45
Сообщение #5


Новичок
*

Группа: Пользователи
Сообщений: 18
Пол: Мужской

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


Цитата
Интересно, что дает конструкция:

c(count):=a[i,j];
k:=1;


это я значения по периметру вношу в массив c.

Цитата
(не вожно какие!)


Извините за ошибку mega_chok.gif

И еще дублирования быть не должно!
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 31.10.2005 23:26
Сообщение #6


Гость






Цитата
дублирования быть не должно!
Тогда так...
const
n = 6;
a: array[1 .. n, 1 .. n] of integer =
(
(1, 2, 3, 4, 5, 6),
(1, 2, 3, 4, 5, 6),
(1, 2, 3, 4, 5, 6),
(1, 2, 3, 4, 5, 6),
(1, 2, 3, 4, 5, 6),
(1, 2, 3, 4, 5, 6)
);

var
i, j: integer;
k, count: integer;

arr: array[1 .. 4 * n] of integer;

procedure add_buffer(x: integer);
begin
inc(count);
arr[count] := X;
end;

begin
count := 0;

for i := 1 to n do add_buffer(a[1, i]);
for j := 2 to pred(n) do
add_buffer(a[j, n]);
for i := n downto 1 do add_buffer(a[n, i]);
for j := pred(n) downto 2 do
add_buffer(a[j, 1]);

for i := 1 to count do
write(arr[i]:4);
writeln;

end.
 К началу страницы 
+ Ответить 
AruNimotsi
сообщение 3.11.2005 18:04
Сообщение #7


мозгоклюй
***

Группа: Пользователи
Сообщений: 205
Пол: Мужской
Реальное имя: Юра

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


Допустим массив NxM элементов (а не 6х6)
в общем случае поиск можно былобы организовать tak


Код

Fori:=1 to n do
  forj:=1 to m do
  if (i=1)or(j=1)or(i=n)or(j=m) then begin end;


и заметьте - никакого дубляжа yes2.gif


--------------------
Иногда ответ ближе чем то место где мы его ищем..
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 3.11.2005 18:12
Сообщение #8


Гость






To: AruNimotsi
Этот способ уже приводился... Пост №4 внимательно читай.

Кстати, при твоем способе порядок следования элементов сохранится? А что автору надо?

Так что подумай, прежде чем что-то написать !!! И Внимательно читай задание и дополнения к нему.
 К началу страницы 
+ Ответить 

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

 



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