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

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в 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
Palza



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ROCUS
по первой задаче:
 насколько я понял, необходимо отобразить все натуральные числа сумма цифр, которых равна конретно заданному числу. Все таки, должно быть ограничение на число цифр, иначе количетво чисел бесконечно много, а еще лучше, если задано конкретное число цифр.

Всего записей: 136 | Зарегистр. 23-07-2005 | Отправлено: 23:29 22-05-2008
ROCUS

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
да ты правильно понял, но фишка в том и состоит что у меня не тянет большие числа, если задать число 99 то один из ответов должен быть 99999999999  
Вот условие задачи " Напечатать ВСЕ натуральные числа сумма  цифр которых =K"
14 =77 734 347 437 617 .... итак далее.  Ограничение числа чем больше тем лучше.
 

Всего записей: 2 | Зарегистр. 22-05-2008 | Отправлено: 10:55 23-05-2008
FuKiNG

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Ребята помогите мне пожалуйста решить 2 задачки.У меня просто практика,а на этой теме меня не было...
1)разработка программ с использованием функций.
 Дан массив Х(n). Определить площади треугольников,которые можно построить используя по 3 различных элемента массива,для которых треугольники существуют.
 
2)Разработка программ с использованием процедур.
 
 Дан текст из нескольких предложений.Удалить из каждого предложения символы, не являющеся буквами русского или английского алфавита.Распечатать исходный и полученый текст.
 
Плиззз решите кто-то эти задачки,а то у же не знаю что делать

Всего записей: 1 | Зарегистр. 23-05-2008 | Отправлено: 23:34 23-05-2008
SERGE_BLIZNUK

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

Цитата:
Вот условие задачи " Напечатать ВСЕ натуральные числа сумма  цифр которых =K"  

ну Вы то хоть сами понимаете, что задача ПРАКТИЧЕСКИ НЕ РЕШАЕМА!!
нельзя напечататать ВСЕ числа (ну, при достаточно большом K)
например, при K = 30000 это будет ОЧЕНЬ МНОГО чисел, последнее из которых будет представлять собой число 1111111...(всего 30000 единичек)...11111
для понимания, если ОДНО это число печатать подряд на стандарном листе A4 - то потребуется около СЕМИ листов....
а если K будет больше?...
 
И ещё. если Вас всё таки не пугают такие числа и такие вычисления, то это всё решается достаточно банально через массив цифр/символов (если не придумаете сами, по поищите по словам ДЛИННАЯ АРИФМЕТИКА - возьмите оттуда тип данных и делайте перебор...)
 


 
FuKiNG

Цитата:
)разработка программ с использованием функций.  
 Дан массив Х(n). Определить площади треугольников,которые можно построить используя по 3 различных элемента массива,для которых треугольники существуют.  

а вот скажите, массив X - что собой представляет? числа?
вот три элемента массива  2 3 4 - ответьте, пожалуйста, можно построить треугольник?!!
поймите, если Вы не знаете, как можно решить задачу БЕЗ компьютера (ну, или другими словами, если Вы не знаете АЛГОРИТМ решения), то запрограммировать решение у Вас вряд ли получится...

Всего записей: 2014 | Зарегистр. 12-09-2002 | Отправлено: 20:46 24-05-2008
Palza



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ROCUS
кстати, как учитывается тот факт, что среди цифр могут встречаться нули?

Всего записей: 136 | Зарегистр. 23-07-2005 | Отправлено: 21:21 24-05-2008
SERGE_BLIZNUK

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

Цитата:
кстати, как учитывается тот факт, что среди цифр могут встречаться нули?

+1 Кстати, супер вопрос!!! действительно а как?!! -))
 

Всего записей: 2014 | Зарегистр. 12-09-2002 | Отправлено: 21:59 24-05-2008
Vaneg



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Народ очень нужна помощь,причем черезвычайно срочно!
Задача:Дана не пустая последовательность  слов из строчных русских букв.Между словами любой знак припенания.Вывести в порядке обратном алфавитному слова оканчивающиеся на согласные буквы с заданным колличеством слогов.
Поесняю конкретику ка надо решить,просто уменя так не получаеться:гласные буквы и знаки припенаниня нужно разместить в два разных множества.Колличества слогов вводим с клавиатуры.А вывести слова нужно в одномерном массиве в порядке убывания.
Помогите плиз!Буду очень признателен!!!
 
Добавлено:
Народ подскажите как мне вывести массив a[r] в обратном алфавитном порядке???
Помогите плиз.Условие моей задачи выше!
 
uses crt;
     var
     st,slovo,b:string;
     m,m1,m2:set of char;
     a:array [1..40] of string;
     i,slog,kol,f,r,h:integer;
 begin
 clrscr;
 writeln('Ввидите не пустую последовательность слов,со знаками припенания');
 readln(st);
 m:=['а','е','ё','и','о','у','ы','э','ю','я'];
 m1:=['.',',','!',';',':','?','-',' '];
 m2:=['б','в','г','д','ж','з','й','к','л','м','н','п','р','с','т','ф','х','ц','ч','ш','щ'];
  writeln('Ввидите колличества требуемых слогов');
  readln(slog);
   slovo:='';
   kol:=0;
   r:=1;
   for i:=1 to length(st) do
   if st[i] in m1 then
   begin
         for f:=1 to length(slovo) do
          if slovo[f] in m then
               kol:=kol+1;
          for    f:=length(slovo) to length(slovo) do
                            if (kol=slog) and (slovo[f] in m2) then
                            begin
                            a[r]:=slovo;
                            r:=r+1;
                            end;
 
 
 
 
 
   kol:=0;
   slovo:='';
   end
 
   else slovo:=slovo+st[i];
 
 
 
 
 
   readkey;
   end.

Всего записей: 6 | Зарегистр. 01-05-2008 | Отправлено: 13:08 25-05-2008
diryska

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
помогите решить задачку  
Дана квадратная матрица {V[i;j]} целочисленных элементов. Найти произведение элементов побочной диагонали и количество нулевых элементов в предпоследнем столбце матрицы.  
Если логарифм первой из этих величин может быть вычислен, то отпечатать значение
произведения данного логарифма и второй из найденных величин. В противном случае отпечатать сумму найденных двух величин.
вот что у меня вышло и не могу понять, в чем ошибочка. Подскажите пожалуйста
Uses Crt;
Var V : Array [1..20, 1..20] of Integer;
     i, j, N : Integer;
     R,S,X,Q : Integer;
Begin
  ClrScr;
  Write('kol strok i stolb - ');
  ReadLn(N);
  For i := 1 to N do
     For j := 1 to N do
       begin Write('V[' , i , ', ' , j , '] = ');
               ReadLn(V[i, j])
       end;
  ClrScr;
  WriteLn('ISXOdnay matriza :'); WriteLn;
  For i := 1 to N do
     begin
       For j := 1 to N do Write(V[i, j] : 5);
       WriteLn
     end;
Begin
R:=1;
For i:=1 to n do
R:=R*V[i,n+1-i];
WriteLn('R=',R);
readln
END;
begin
for i:=1 to n do
if V[i,j-1]=0 then
S:=S+1;
writeln('s=',S);
readln
end;
if R>=0 then
begin
X:=ln(R)*S;
writeln ('X=',X);
end;
else
begin
Q:=S+R;
writeln('summa=',Q);
end;
readln
end.

Всего записей: 1 | Зарегистр. 25-05-2008 | Отправлено: 18:15 25-05-2008 | Исправлено: diryska, 23:08 25-05-2008
Palza



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

Цитата:
if R>=1 then

логарифм от числа существует, если само число положительное, а не больше еденицы.

Всего записей: 136 | Зарегистр. 23-07-2005 | Отправлено: 22:35 25-05-2008
Lenor

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
хелп!!очень нуна помощь..бьюсь-бьюсь,а что то все время не выходит.
нужно перемножить два 20-значных десятичных ЦЕЛЫх числа.

Всего записей: 3 | Зарегистр. 20-05-2008 | Отправлено: 20:39 26-05-2008
Palza



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Lenor
http://forum.pascal.net.ru/index.php?showtopic=2428

Всего записей: 136 | Зарегистр. 23-07-2005 | Отправлено: 22:27 26-05-2008
svi91

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Такой вопрос.
 
Задача - Организовать с клавиатуры ввод N произвольных целых чисел. Найти количество кратных 5 и произведение оставшихся.
 
Решение:
 
Program N7;
Uses CRT;
var
x,i,n,m:word;
proiz:longint;
begin
clrscr;
writeln('vvedite kol-vo  chisel');
readln(n);
proiz:=1;
For i:=1 to n do begin
writeln('vvedite luboe chislo');
readln(x);
If (x mod 5=0) then
inc(m)
else
proiz:=proiz*x;
end;
 
 
writeln('kol-vo kratnux 5=', m);
writeln('proizvedenie ost=',proiz);
writeln;
writeln;
writeln;
writeln('chtobu vuyti iz programmu ili vernutsya k kodu nazhmite - enter');
readln;
end.
 
 
 
В чем бок, если все числа кратны 5. То произведение оставшихся должно быть равно 0, а не единице как получается в проге. Помогите устранить.

Всего записей: 4 | Зарегистр. 18-05-2008 | Отправлено: 19:29 27-05-2008
SERGE_BLIZNUK

Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
svi91
так и должно быть. Ведь, чтобы перемножить числа, произведение иницилизируется единицей.
Побороть этот эффект можно только через доп.проверку:
либо вначале программы proiz  := 0;  
и в цикле:
Код:
 
else {x mod 5 =0 }  
  if proiz = 0 then proiz := x
  else proiz:=proiz*x;  
 

 
либо в конце проверять, если количество кратных чисел m = общему числу n
то proiz := 0;

Всего записей: 2014 | Зарегистр. 12-09-2002 | Отправлено: 09:23 28-05-2008
Chih Pih

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Люди! Очень нужна помощь. Борода. Не хватает мозга уже.
условие следующее:
сформировать файл F целого типа. Из файла получить матрицу А(N,M).
Начиная с 1-й и по (N-1) строки формировать, читая компоненты файла с начала, N-ю строку заполнить компонентами, читая файл с конца. Матрицу распечатать. Если матрицы сформировать нельзя, то сделать сообщение.Значения N,M вводятся с клавиатуры.

Всего записей: 1 | Зарегистр. 29-05-2008 | Отправлено: 11:32 29-05-2008 | Исправлено: Chih Pih, 11:34 29-05-2008
Core_Cell

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Доброго времени суток, уважаемые форумчане.
Помогите пожалуйста разобраться в проблеме:
Задан файл, текстовый, в нем информация о людях в виде:
фамилия имя отчество DDMMYYY A B С D город улица дом квартира телефон.
Нужно раскидать эти данные в запись.
Я сделал это так:
 
Подробнее...
 
Проблема в том, что у меня в одной из процедур - FillFlag см. код, отказывается присваивать значение глобальной переменной. Не могу понять в чем дело, помогите пожалуйста.
 

Всего записей: 25 | Зарегистр. 13-03-2007 | Отправлено: 23:27 29-05-2008 | Исправлено: Core_Cell, 23:44 29-05-2008
ymg2000



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Core_Cell
У тебя параметр в порцедурах s объявлен как var.
Посмотри в отладчике, какое значение несет переменная s к моменту вызова FillFlag(s). Думаю, она уже сильно усечена.
 
Добавлено:
Core_Cell
У тебя параметр в порцедурах s объявлен как var.
Посмотри в отладчике, какое значение несет переменная s к моменту вызова FillFlag(s). Думаю, она уже сильно усечена.

Всего записей: 2391 | Зарегистр. 24-08-2007 | Отправлено: 10:49 30-05-2008
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Core_Cell
а что за getchar() такая? откуда ты её взял?

Всего записей: 24849 | Зарегистр. 06-12-2002 | Отправлено: 12:41 30-05-2008 | Исправлено: akaGM, 18:07 30-05-2008
Rofl007

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Очень нужна Ваша помощь. Задание для мея совсем непонятное...
Задача:
Составить программу для обработки информации о соревноваии. Соревноваие проводится двумя группами по 10 человек. Подведение итогов проводится по каждой группе. Результатом является списки участиков по группам в порядке занятых ими мест. Необходимо получить общий список, отсортированый по соответствию показателям результатов. Обработку результатов соревнований по каждой группе оформить в виде подпрограммы.

Всего записей: 1 | Зарегистр. 30-05-2008 | Отправлено: 21:26 30-05-2008
creer

Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Думаю, задание примерно такое. Есть список результатов игр, примерно:
Участник 1 - Участник 2
2 - 1
Участник 2 - Участник 3
0 - 0
и т. д.
Нужно получить список:
1. Участник 1
2. Участник 2
3. Участник 3
и т. д.
В простом случае, просто суммируем баллы каждого участника, и сортируем по ним.

Всего записей: 38 | Зарегистр. 18-11-2005 | Отправлено: 17:52 01-06-2008
mixser1990

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Дано описание типов:  
          TYPE  MAST=(PIKI,TREF,BUBN,CHER);  
                    ZNACH=(K6,K7,K8,K9,K10,KVAL,KDAM,KKOR,KTUZ};  
                    KARTA=RECORD  
                                   M:MAST;  
                                    Z:ZNACH;  END;  
Случайным образом выбирается К1-первая карта, К2-вторая кар¬та, КМ - козырная масть. Бьет ли К1  К2?
 
чё-то никак не получается решить

Всего записей: 6 | Зарегистр. 01-06-2008 | Отправлено: 18:59 01-06-2008
Открыть новую тему     Написать ответ в эту тему

Страницы: 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