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

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

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

> заполнения матрицы по спирали, просто обьясните
Darkmaximus
сообщение 9.12.2004 1:59
Сообщение #1





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

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


huh.gif Кто ни будь может обьяснить мне алгоритм этой проги “заполнения матрицы по спирали” третий день бьюсь не могу понять.


Код

program spirall;
uses crt;
const Size=7;
k=0; {"яєёЄр   ўхщър" ёюфхЁцшЄ чэрўхэшх k}
var mas:array[1..size,1..size]of shortint;
i,j,a:integer;

function freemas(i,j: shortint): boolean;
begin
if (i<1) or (i>size) or (j<1) or (j>size)
then freemas:=false
else freemas:=(mas[i,j]=k);
end;

begin
clrscr;
i:=1;
j:=1;
mas[i,j]:=1;

for a:=2 to sqr(size) do
begin
 if (freemas(i-1,j)) and (not freemas(i,j-1)) then begin dec(i); mas[i,j]:=a; end else
 if freemas(i,j+1) then begin inc(j); mas[i,j]:=a; end else
 if freemas(i+1,j) then begin inc(i); mas[i,j]:=a; end else
 if freemas(i,j-1) then begin dec(j); mas[i,j]:=a; end else
 readln;
end;

begin
writeln;
for i:=1 to size do begin
 for j:=1 to size do write(mas[i,j]:2,'|');
 writeln;
 end;
end;

readln;
end.


Не забываем теги [ code] и [ /code] для исходников...

Сообщение отредактировано: volvo - 9.12.2004 2:03
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов(1 - 2)
Флогримм
сообщение 9.12.2004 5:32
Сообщение #2


Бывалый
***

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

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


Код
program spirall;
uses crt;
const Size=7;
k=0; {элемент пустой матрицы}
var mas:array[1..size,1..size]of shortint;
i,j,a:integer;

function freemas(i,j: shortint): boolean; {определяет, является ли ячейка массива с координатами i,j - пустой}
begin
if (i<1) or (i>size) or (j<1) or (j>size) {если не выходит за границы матрицы}
then freemas:=false
else freemas:=(mas[i,j]=k); {если равна значению пустой ячейки, тогда функция принимает значение true}
end;

begin
clrscr;
i:=1;
j:=1;
mas[i,j]:=1;

for a:=2 to sqr(size) do
begin
if (freemas(i-1,j)) and (not freemas(i,j-1)) then begin dec(i); mas[i,j]:=a; end else {если есть пустая ячейка сверху, тогда увеличим уменьшим на 1 координату i и присвоим mas[i,j]-текущую цифру а (это равносильно передвижению по массиву на 1 ячейку вврх)}
if freemas(i,j+1) then begin inc(j); mas[i,j]:=a; end else{если свободная ячейка справа, тогда...}
if freemas(i+1,j) then begin inc(i); mas[i,j]:=a; end else {если свободная ячейка внизу...}
if freemas(i,j-1) then begin dec(j); mas[i,j]:=a; end else{...слева...}
readln;
end;

begin
writeln;
for i:=1 to size do begin
for j:=1 to size do write(mas[i,j]:2,'|'); {прорисовка массива на экране}
writeln;
end;
end;

readln;
end.


примечание:
dec(x) - уменьшает значение x на 1;
dec(x, a) - уменьшает значение х на а


--------------------
Я не буду жить с этой злобой внутри / Я не буду частью смертельной цепи / Я не буду потребителем твоих идей / Я не буду никогда убивать зверей (Unconform)
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Флогримм
сообщение 9.12.2004 5:47
Сообщение #3


Бывалый
***

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

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


Дружище, посмотри еще вот эту тему Алгоритмы на матрицах huh.gif


--------------------
Я не буду жить с этой злобой внутри / Я не буду частью смертельной цепи / Я не буду потребителем твоих идей / Я не буду никогда убивать зверей (Unconform)
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 



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