1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
| Bush |
Сообщение
#1
|
|
Группа: Пользователи Сообщений: 6 Пол: Мужской Репутация: 0 |
Задача на мой взгляд не простая поэтому и лбращаюсь за помощью.
Дана матрица,записанная в текстовый файл.Сдвинуть элементы заданной матрицы в пределах каждого слоя на одну позицию по часовой стрелке.Первый слой образуется из элементов находящихся по периметру матрицы,второй по периметру оставшейся подматрицы и т.д. до заполнения всей матрицы.Полученную матрицу дописать в файл.На экране расскрасить слои разными цветами. Если есть возможность помогите пожалуйста. |
![]() ![]() |
| -TarasBer- |
Сообщение
#2
|
|
Гость |
> Это, конечно, сильно увеличит время выполнения, но это общий закон: либо память - либо время.
В данном случае это не так. Для того, чтобы сделать циклический сдвиг массива из m элементов на n, надо НОД(m,n) раз сделать такую операцию: взять k-ый элемент (k - это номер операции, то есть мы делаем это сначала для k=0, потом для k=1, и так далее до k=НОД(m,n)-1) и поменять его местами с k+n-ым. Потом k+n-ый поменять с k+n+n b так далее, пока не окажется, что новый элемент, с которым надо менять, имеет индекс k. Вообще в цепочке длины L надо выполнить L-1 обмен. Кстати, L = m / НОД(m,n) Короче, если грузануть хитрую алгебру, то можно без затрат обойтись без доп.массива. |
| Lapp |
Сообщение
#3
|
![]() Уникум ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 6 823 Пол: Мужской Реальное имя: Лопáрь (Андрей) Репутация: 159 |
> Это, конечно, сильно увеличит время выполнения, но это общий закон: либо память - либо время. В данном случае это не так. Для того, чтобы сделать циклический сдвиг массива из m элементов на n, надо НОД(m,n) раз сделать такую операцию: взять k-ый элемент (k - это номер операции, то есть мы делаем это сначала для k=0, потом для k=1, и так далее до k=НОД(m,n)-1) и поменять его местами с k+n-ым. Потом k+n-ый поменять с k+n+n b так далее, пока не окажется, что новый элемент, с которым надо менять, имеет индекс k. Вообще в цепочке длины L надо выполнить L-1 обмен. Кстати, L = m / НОД(m,n) Короче, если грузануть хитрую алгебру, то можно без затрат обойтись без доп.массива. Я в трансе Как будет время, попробую реализовать. Тарас, мож тиснешь для FAQ? И, пожалуйста, кинь тут свой пост (а не гостя). Я понимаю, что ты не "кармадрочер" (модное словцо с твоей же легкой руки, подхваченное volvo, но я не могу писать его иначе как в кавычках)), но ставить +1 из другой темы - неправильно.. )) -------------------- я - ветер, я северный холодный ветер
я час расставанья, я год возвращенья домой |
Bush Двумерные массивы 21.11.2006 15:32
volvo Что именно вызывает затруднения? Чтение матрицы из… 21.11.2006 16:45
Merhaba
Объясните Пожалуйста, если вам не трудно, принц… 19.04.2011 0:46
Bush Поворот слоев. 21.11.2006 22:25
volvo const
num_row = 5;
num_col = num_row;
type
… 21.11.2006 23:25
Bush Вроде ясно.Спасибо. 22.11.2006 22:28
volvo Добавил немного комментариев. Так понятнее? 19.04.2011 1:00
Merhaba
Добавил немного комментариев. Так понятнее?
А ка… 19.04.2011 1:08
Lapp А как можно написать эту программу без использован… 19.04.2011 6:40
Merhaba
Извиняюсь за вторжение..
Можно, конечно. Наприм… 19.04.2011 9:47
Lapp а как можно переделать код, где 1-ый слой будет сд… 19.04.2011 9:54
Merhaba
Что переделать??
Ты читай ВНИМАТЕЛЬНО, что тебе п… 21.04.2011 0:31
Lapp Объясните Пожалуйста, что такое Dec(k) ?Это эквив… 21.04.2011 14:25
Merhaba
Это эквивалентно выражению
[code=pas]k := k-1;
Ил… 22.04.2011 13:10
Lapp Объясните Пожалуйста, что такое [code=pas]b:= a[i,… 22.04.2011 15:04
TarasBer Ну, в данном случае это извращение довольно просто… 22.04.2011 13:12![]() ![]() |
|
Текстовая версия | 5.11.2025 1:17 |