29.05.2017, 08:51 [+3 UTC]
в нашей команде: 1 986 чел. | участники онлайн: 7 (рекорд: 21)

:: РЕГИСТРАЦИЯ

:: консультации

:: задать вопрос

:: все разделы

:: правила

:: новости

:: участники

:: доска почёта

:: форум

:: блоги

:: поиск

:: статистика

:: наш журнал

:: наши встречи

:: наша галерея

:: отзывы о нас

:: поддержка

:: руководство

Версия системы:
7.41 (25.02.2017)

Общие новости:
23.02.2017, 09:51

Форум:
28.05.2017, 22:13

Последний вопрос:
28.05.2017, 20:41

Последний ответ:
26.05.2017, 23:58

Последняя рассылка:
28.05.2017, 20:15

Писем в очереди:
0

Мы в соцсетях:

Наша кнопка:

RFpro.ru - здесь вам помогут!

Отзывы о нас:
25.03.2011, 04:01 »
Данилов Артем Владимирович
Большое спасибо за быстрый и точный ответ - дело было как раз в данном обновлении [вопрос № 182556, ответ № 266377]

РАЗДЕЛ • Pascal / Delphi / Lazarus

Создание программ на языках Pascal, Delphi и Lazarus.

[администратор рассылки: Зенченко Константин Николаевич (Модератор)]

Лучшие эксперты в этом разделе

Зенченко Константин Николаевич
Статус: Модератор
Рейтинг: 132
mklokov
Статус: 5-й класс
Рейтинг: 105
Ксюша
Статус: 1-й класс
Рейтинг: 2

Перейти к консультации №:
 

Консультация онлайн # 137971
Раздел: • Pascal / Delphi / Lazarus
Автор вопроса: Хощенко Артём Владимирович
Отправлена: 27.05.2008, 09:00
Поступило ответов: 1

Здравствуйте, уважаемые эксперты! Я начал изучил процедуры и функции, поэтому эту задачу нужно разбить на максимальное количесво процедур и функций (три процедуры обязательны: ReadDate, Move, Print). Я прошу, чтобы вы подкинули мне идею написания программы. Ну что-то ничего в голову не идёт!
По круку записаны n (n < 100) чисел - одна единица и остальные нули. Каждую секунду вместо числа x(k) (в круглых скобках я пишу индекс) пишут |2x(k)-x(k-1)-x(k+1)|. Определите, какие числа будут через n секунд. Выведите все промежуточные результаты, как указано ниже:
15
0: 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0
1: 2 1 0 0 0 0 0 0 0 0 0 0 0 0 1
2: 2 0 1 0 0 0 0 0 0 0 0 0 0 1 0
3: 4 3 2 1 0 0 0 0 0 0 0 0 1 2 3
4: 2 0 0 0 1 0 0 0 0 0 0 1 0 0 0
5: 4 2 0 1 2 1 0 0 0 0 1 2 1 0 2
6: 4 0 3 0 2 0 1 0 0 1 0 2 0 3 0
7: 8 7 6 5 4 3 2 1 1 2 3 4 5 6 7
8: 2 0 0 0 0 0 0 1 1 0 0 0 0 0 0
9: 4 2 0 0 0 0 1 1 1 1 0 0 0 0 2
10: 4 0 2 0 0 1 1 0 0 1 1 0 0 2 0
11: 8 6 4 2 1 1 1 1 1 1 1 1 2 4 6
12: 4 0 0 1 1 0 0 0 0 0 0 1 1 0 0
13: 8 4 1 1 1 1 0 0 0 0 0 1 1 1 4
14: 8 1 3 0 0 1 1 0 0 1 1 0 0 3 1
15: 14 9 5 3 1 1 1 1 1 1 1 1 3 5 9

Вся соль в том, что числа записаны по кругу. Заранее благодарен!

Состояние: Консультация закрыта

Ответ # 224444 от Delph

Здравствуйте, Хощенко Артём Владимирович!

Задача лекго решилась при помощи вспомогательного массива. Обратите внимание: вспомогательный массив Tmp обладает чуть более широкими границами, чем основной, иначе пришлось бы очень аккуратно проверять индексы и при выходе за границы массива перекидывать их на противоположный конец. Граничные значения Tmp берутся с противоположных концов основного массива Arr, что позволяет легче реализовать "закольцованность" данных. Основная же задача Tmp - хранение неизменного "снимка" данных с прошлого шага, когда на текущем шаге данные уже меняются.

Приложение:


Консультировал: Delph
Дата отправки: 27.05.2008, 09:59

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

Возможность оставлять сообщения в мини-форумах консультаций доступна только после входа в систему.
Воспользуйтесь кнопкой входа вверху страницы, если Вы зарегистрированы или пройдите простую процедуру регистрации на Портале.

Яндекс Rambler's Top100

главная страница | поддержка | задать вопрос

Время генерирования страницы: 0.25713 сек.

© 2001-2017, Портал RFPRO.RU, Россия
Авторское право: ООО "Мастер-Эксперт Про"
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.41 от 25.02.2017
Бесплатные консультации онлайн