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

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

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

 
 Ответить  Открыть новую тему 
> заполнения матрицы по спирали, просто обьясните
сообщение
Сообщение #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 -
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #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 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Бывалый
***

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

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


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


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

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

 





- Текстовая версия 19.05.2024 4:57
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name