Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Задачи на Pascal/Object Pascal/Free Pascal (Delphi/Lazarus)

Модерирует : ShIvADeSt

 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434

Открыть новую тему     Написать ответ в эту тему

buffy



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Задачи и Программирование на языке Pascal/Object Pascal (Turbo, Delphi и Free Pascal)

 
Перед тем, как задать вопрос: загрузите "версию для печати" (ссылка справа вверху, над номерами страниц) и попробуйте поискать средствами браузера (ctrl+F). Большинство типовых задач уже решались, причем неоднократно!  
ВНИМАНИЕ!

Текст всех программ обязательно заключайте в теги [code][/code].
Большие тексты (более 15 строк) обязательно прячутся в [more]ВАШ ТЕКСТ и/или Ваш КОД[/more]


Альтернативный компилятор
Free Pascal Compiler (FPC) -- мощный компилятор Паскаля
 - девиз: пишешь единожды, компилируешь где хошь...
 - на 99% совместим по коду с ТР и Object Pascal (Delphi)
 - межплатформенный
 - свободный  
Lazarus -- среда разработки для FPC (аналог среды Delphi7)
 
Файлы
Русская справка
Turbo Pascal 7.1 добавлены некоторые модули из Borland Pascal, русская справка.
Borland Pascal 7.0 Полный (13-дискетный, вкл. исходники), никем не модифицированный  дистрибутив.
 
Учебники:
В.В.Фаронов - Turbo Pascal. Начальный курс
В.В.Фаронов - Turbo Pascal. Наиболее полное руководство
Д.М.Ушаков, Т.А.Юркова - Паскаль для школьников
С.М.Окулов - Основы программирования
С.М.Окулов - 2 главы из школьного учебника по информатике
В.М.Котов - Олимпиадные задачи по информатике с решениями
Никитин - набор исходников для типовых задач
Мансуров - Основы программирования в среде Lazarus - основы паскаля, много примеров, блоксхем, алгоритмов. 2010. 772 с. примеры к книге
Деревенец - Песни о Паскале - паскаль для школьников и студентов-первокурсников
Епанешниковы - Программирование в среде Turbo Pascal
Паскаль для школьников. Подготовка к ЕГЭ (2011)
Фадеев - Паскаль для школы
Потопахин - Turbo Pascal Решение сложных задач (2006)
Полезные линки
библиотека алгоритмов (есть и на Паскале)
библиотека алгоритмов (ещё одна)
библиотека алгоритмов (и ещё одна)
Разбор олимпиадных задач по информатике от Михаила Густокашина
 
Проблема с набором русского текста в консоли/Turbo Pascal
решение проблемы с набором русского текста в консоли Windows  скриптом (командным файлом)
 
Построение блок-схем
FCEditor -- Программа для автоматического построения блок-схем программ из исходного текста на языке Pascal (Delphi)
 - для правильной работы исходный текст должен начинаться со слова program или unit

Всего записей: 4 | Зарегистр. 24-10-2002 | Отправлено: 12:46 11-01-2003 | Исправлено: akaGM, 23:06 21-11-2019
Viwwna



Junior Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
KChernov
Не буду я на Вас жаловаться ни куда, раз вы не понимаете, сами, что унижаете подобными выводами и имеете привычку просто выдергивать определенные слова из предложения и комментировать  и изворачивать их как вздумается, как удобнее Вам. Там, где вы меня называете НЕУЧЕМ - Я цитату выделила,- а вы снова- ГДЕ ФАКТЫ??? А мне все равно смешно, когда человек так может..... ладно не буду.... ВООБЩЕМ, БУДУ ДЖЕНТЛЬМЕНОМ (трагедия наших дней) и уступлю Вам...  
ПОБАРАБАНУ Вам, когда другие Вам указывают, на ваши ошибки , на Ваше поведения/слова, Вам главное, что бы Вы были о себе хорошего мнения)))) -тупиковый путь))) Главное, не останьтесь совсем уж ТЕТ-а-ТЕТ самим с собой, с таким ВЕРОВАНИЕМ, что Вы правы, все знаете и все видите.

Всего записей: 62 | Зарегистр. 18-11-2011 | Отправлено: 22:04 27-11-2011
murkovich



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
KChernov
Viwwna
ребята, давайте жить дружно!

Всего записей: 1551 | Зарегистр. 26-05-2005 | Отправлено: 22:30 27-11-2011
KChernov



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Viwwna
Насчёт:
Цитата:
Ну писать тут вы много чего можете (чем и пользуетесь).
Да и как будто мало у нас в стране неучей по блату на тёплые места пристроены - нашли чем удивить, право.

На самом деле только первое предложение цитаты было утверждением, а второе строилось в сослагательном наклонении чуть ли не как логический вывод из предыдущего диалога в предположении, что это заставит вас задуматься.
Но вы почему-то упорно вцепились в эту фразу и приняли её на свой счёт, а я в потоке вашего сознания не выделил этот факт и не дал на него ответ сразу (хотя я почему-то уверен, что это не помогло бы).
Со своей стороны считаю всё случившееся своим личным провалом, ибо моя цель (которая никогда не состояла в том, чтобы как-то вас выставлять/оскорблять - мне это не интересно -, но побудить к действию) так и не была достигнута. Но не ошибается тот, кто ничего не делает.

Всего записей: 2471 | Зарегистр. 20-04-2004 | Отправлено: 23:30 27-11-2011
A1exSun



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
KChernov
Ответь мне пожалуйста.

Всего записей: 1871 | Зарегистр. 25-11-2009 | Отправлено: 01:32 28-11-2011
KChernov



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
A1exSun

Цитата:
Что-то я не представляю как оно выглядит, по этой "полноценной рекурсивной печати бинарного дерева с отступами".
Не вижу ничего общего с этой картинкой:  

Это же не какая-то левая прога, а ваш личный код.
Всегда можно сделать так, чтобы лучше было видно.
Вот исправленный вариант.
 

Цитата:
Значение левой ветки меньше, правой больше?  

Именно.
 

Цитата:
Условие:
 
Код:
type TED = <любой тип>;
дерево =^ верхушка;  
верхушка = record
элемент: TED;
левая, правая: дерево;
end;
 
inform убрать нафиг?

По-хорошему и имена надо бы привести в соответствие.
Хотя зависит от требований к решению.
 

Цитата:
random()>=0,5
 
random без параметров выдает или 0 или 1, зачем >=0,5 ?

Это не так - тут хитрый random.
Наконец-то прочитал полную версию хелпа - в данном случае правильно будет random(2).
 
Вот код для этого варианта - как говорится найдите 10 отличий.

Всего записей: 2471 | Зарегистр. 20-04-2004 | Отправлено: 01:41 28-11-2011 | Исправлено: KChernov, 01:43 28-11-2011
A1exSun



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
KChernov

Цитата:
Это же не какая-то левая прога, а ваш личный код.

Нет, Вы же знаете откуда я его взял?

Цитата:
исправленный вариант

Смотреть - голову на 90 градусов против часовой стрелки?
Цитата:
Введите число потомков n: 20
              --92
          --95
                  --33
              --84
      --33
          --11
                  --12
                      --29
              --62
                  --94
  --96
              --95
                  --40
                      --35
          --33
      --69
                  --5
              --70
          --48
              --16
Введите искомое число e: 84
Кол-во встречающихся: 1

От 11 или от 95 одна ветка. И еще там... Так и должно быть?
 

Код:
procedure del(var t: tree);
begin
    if t <> nil then begin
        if t^.r <> nil then del(t^.r);
        if t^.l <> nil then del(t^.l);
        dispose(t);
    end;
end;
Правильное освобождение памяти?
 
Спасибо за помощь.

Всего записей: 1871 | Зарегистр. 25-11-2009 | Отправлено: 02:25 28-11-2011 | Исправлено: A1exSun, 02:38 28-11-2011
KChernov



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
A1exSun

Цитата:
Нет, Вы же знаете откуда я его взял?

Значит какие-то проблемы с пониманием этого кода остались?
 

Цитата:
Смотреть - голову на 90 градусов против часовой стрелки?

Можно нарисовать повёрнутым.
А можно выгрузить в файл и посмотреть визуализатором деревьев.
А можно его прицепить к самой программе.
Просто текущий вариант - самый простой.
 

Цитата:
От 11 или от 95 одна ветка.  

Если надо это увидеть, можно выводить ещё и параметры родителя.
Но это не поможет для рядом расположенных одинаковых значений.
Но можно вообще все вершины занумеровать (поскольку дерево бинарное, то бинарное нумерование будет самым наглядным, но и самым громоздком) и выводить 3 числа: № родителя, № текущего и значение текущего.
 

Цитата:
Так и должно быть?  

Что конкретно должно?
 

Цитата:
Правильное освобождение памяти?  

Да вроде работает.
 

Цитата:
Спасибо за помощь.

На здоровье.

Всего записей: 2471 | Зарегистр. 20-04-2004 | Отправлено: 07:54 28-11-2011
A1exSun



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
KChernov

Цитата:
Значит какие-то проблемы с пониманием этого кода остались?

Нет, кроме вывода дерева.

Цитата:
Можно нарисовать повёрнутым.

Как?

Всего записей: 1871 | Зарегистр. 25-11-2009 | Отправлено: 14:33 28-11-2011
Simkara

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Такой вопрос.
Имеется:
x:=n/2 {n - вводим с клавиатуры}
 
Нужно поставить счетчик таким образом, что бы он начинал отчет с x до n
 
Но если прописать:
for i:=x to n do
 
Выводит ошибку 39: предполагается порядковое выражение.
 
Что делать?

Всего записей: 43 | Зарегистр. 26-11-2011 | Отправлено: 17:11 28-11-2011
A1exSun



Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Simkara

Код:
var x, n: integer;
...
x := n div 2;

Всего записей: 1871 | Зарегистр. 25-11-2009 | Отправлено: 17:12 28-11-2011
Simkara

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
A1exSun
Ага, спасиб.

Всего записей: 43 | Зарегистр. 26-11-2011 | Отправлено: 19:02 28-11-2011
KChernov



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
A1exSun

Цитата:
Можно нарисовать повёрнутым.
Как?  

Переписать рисовалку, чтобы она по уровням выдавала.
А чтобы минимально разваливалась, желательно знать/найти максимальную глубину.

Всего записей: 2471 | Зарегистр. 20-04-2004 | Отправлено: 20:23 28-11-2011
indapublic



BANNED
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Кончайте выяснять кто умнее, невозможно быть продвинутым во всех областях. Если ко мне подходит племянница и просит помочь сделать задание по русскому языку, то я просто впадаю в ступор, все эти корни, приставки и т.п. Получается, я тоже неуч и меня на других специализированных форумам можно гнобить?

Всего записей: 200 | Зарегистр. 05-02-2008 | Отправлено: 04:44 29-11-2011
natik2011

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Помогите еще разок, один раз меня тут уже выручили, не оставьте сейчас в беде. ;-(
 
Дано натуральное число n. Выяснить входит произвольная цифра m в запись числа n^2, если да, то приписать единицу в начало числа n, в противном случае поменять порядок цифр числа n на обратный

Всего записей: 19 | Зарегистр. 27-11-2011 | Отправлено: 04:56 29-11-2011
indapublic



BANNED
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Для того чтобы определить входит ли заданное число m в число n попробуйте следующий алгоритм. Что делать дальше подумайте сами
var
 n,m:integer;
 f: boolean;
begin
 readln(n,m);
 n:=n*n;
 while (n<>0) and (F=False) do
   if (n mod 10=m) then f:=True  
   else n:=n div 10;      
    readln;
 end.

Всего записей: 200 | Зарегистр. 05-02-2008 | Отправлено: 05:02 29-11-2011
natik2011

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Ну с этим боле-менее понятно, подскажите, хоть немного, как делать ветвления и действия с числом дальше. По-моему именно это самое трудное.

Всего записей: 19 | Зарегистр. 27-11-2011 | Отправлено: 05:06 29-11-2011
indapublic



BANNED
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Сама алгоритм придумай, а как его реализовать это другой вопрос. Вариантов множество. Первый, записываем число в строку,смотрим сколько символов в строке,а затем умножаем число на 10^, можно не пользоваться строковыми переменными, запоминать числа в массив, а потом уже сформировать само число.  Определись, что ты хочешь получить, а потом задай вопрос "Как это сделать?"

Всего записей: 200 | Зарегистр. 05-02-2008 | Отправлено: 05:36 29-11-2011
KChernov



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
indapublic

Цитата:
Кончайте выяснять кто умнее, невозможно быть продвинутым во всех областях. Если ко мне подходит племянница и просит помочь сделать задание по русскому языку, то я просто впадаю в ступор, все эти корни, приставки и т.п. Получается, я тоже неуч и меня на других специализированных форумам можно гнобить?

Печально, что меня не поняли и восприняли всё это как попытку самоутверждения и гнобление.
Но всё равно спасибо за мнение.
 
Добавлено:
natik2011

Цитата:
Дано натуральное число n. Выяснить входит произвольная цифра m в запись числа n^2, если да, то приписать единицу в начало числа n, в противном случае поменять порядок цифр числа n на обратный

Поскольку в итоге всё равно придётся оперировать с отдельными разрядами числа n^2, я бы сразу разложил его на отдельные цифры и оперировал уже с ними.
 
Добавлено:

Цитата:
как делать ветвления

Чтобы сделать ветвление, нужно условие и языковая конструкция.
Условие в примере indapublic-а вырабатывается, а в качестве конструкции можно использовать if.
 

Цитата:
и действия с числом дальше

При разбиении на разряды это уже совсем просто.

Всего записей: 2471 | Зарегистр. 20-04-2004 | Отправлено: 08:58 29-11-2011 | Исправлено: KChernov, 08:59 29-11-2011
Viwwna



Junior Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору

Цитата:
Кончайте выяснять кто умнее, невозможно быть продвинутым во всех областях. Если ко мне подходит племянница и просит помочь сделать задание по русскому языку, то я просто впадаю в ступор, все эти корни, приставки и т.п. Получается, я тоже неуч и меня на других специализированных форумам можно гнобить?

indapublic, поймите у KChernov метод обучения (как я поняла) в стимуляции (которая больше похожа на раззадоривание -как метода побуждения к изучению предмета (в данном случае языка  Pascal)-  и надо отдать должное этот метод работает, правда, лишь тогда, когда человек, хотел словить ХАЛЯВУ , а его обозвали неучем... и что бы доказать обратное... человек прикладывает усилия и приступает к изучению. (как то так -)) )... но у меня был другой случай (не хватает знаний - из чтения сухой теории)хотела посоветоваться и получила ВОТ такой стимул....Ни чего страшного в принципе не произошло.....
 
А может просто задело KChernov, что какая то "зеленая" говорит здесь свою должность в оправдание, что не дурочка она.... антипатия тоже бывает иногда не обоснована... и такое бывает... все мы люди субъективные))))
 
В ЛЮБОМ СЛУЧАЕ, КОНФЛИКТ СЧИТАЮ ИСЧЕРПАННЫМ. РАЗБОРОК БОЛЬШЕ С МОЕЙ СТОРОНЫ НЕ БУДЕТ....))) теперь на других спец. сайтах "черпаю"/спрашиваю непонятную мне информацию.  
 
Всем, кто здесь подсказывал мне, все,что не было понятно, еще раз ОГРОМНОЕ  THANK YOU!!!!!!

Всего записей: 62 | Зарегистр. 18-11-2011 | Отправлено: 11:11 29-11-2011 | Исправлено: Viwwna, 11:12 29-11-2011
Irok FOX

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Доброго всем дня!
 мне необходимо задачку решить)))):
type
reals = file of real;
var f : reals;
Напишите рекурсивную программу, которая печатает сначала все отрицательные элементы этого файла, а затем положи-тельные (в любом порядке).
 
Может, кто , если не затруднит.. поможет....???

Всего записей: 11 | Зарегистр. 29-11-2011 | Отправлено: 13:41 29-11-2011
Открыть новую тему     Написать ответ в эту тему

Страницы: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Задачи на Pascal/Object Pascal/Free Pascal (Delphi/Lazarus)


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru