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

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



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

Цитата:
 переменные цикла (которые i, j) должны быть локальными

А у меня не будет конфликтовать программа, из за одинаковых локальных и глобальных переменных?
и еще можно узнать как произвести поиск разных элементов в массиве (если 2 элемента например повторяются, то считать только за 1) например массив  
1 2  
3 1 должно вывести "3"

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 21:05 12-12-2014
dimitriy7



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

Цитата:
А у меня не будет конфликтовать программа

Не будет, тем более так и положено делать.

Цитата:
как произвести поиск разных элементов в массиве  

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

Всего записей: 2946 | Зарегистр. 09-10-2008 | Отправлено: 21:16 12-12-2014
mmotop20oo12



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
т.е. я делаю тек?
for q:= 1 to n do  
for p:= 1 to n do  
 begin  
  x:=a[q,p];  
  k:=0;  
  for s:= 1 to n do  
  for d:= 1 to n do  
  if a[s,d]=x then k:=k+1;  
  end;  
 
или тут что то лишенее? просто я рассуждаю так:
1) 1ые 2 щетчика заходят в элемент дапустим а(1 1) обнулаем щетчик неповторных элементов (k)
начинаю еще 2 щестчика выходит я сравниваю а(1 1) с Х (с кода) потом сравниваю а(1 2) с Х и тд в итоге я нарастил щетчик к допустим вышло 3 числа, и поле того как я обратно прыгну во 2ой цикл " for p:= 1 to n do" уже элемент станет а (1 2) и к обнулиться... и итоге получится абычто..., помогите пожалуйсто кодом. у меня не варет котелок так мощно...

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 22:54 12-12-2014
landy



Full Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mmotop20oo12, тебе нужно добавить вывод числа на экран в случае, если k=1 (т.е. этот элемент уникален) после завершения поискового цикла.

Всего записей: 576 | Зарегистр. 17-01-2003 | Отправлено: 23:06 12-12-2014
dimitriy7



BANNED
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mmotop20oo12
Ну как-то так, да. Только просматривать по s,d надо не по всему массиву, а до текущего элемента a[q,p]; переменная x лишняя, почему бы сразу не сравнить с a[q,p]?  

Цитата:
уже элемент станет а (1 2) и к обнулиться

С чего бы вдруг? Оно не сразу же обнулится, перед k:=0 надо проверить k и увеличить (или не увеличить) счетчик (кстати, а где он? Нет его).
 
Вот как-то так надо:

Код:
 
procedure TForm1.какая_то_там(Sender: TObject);
    var  
    i,j,k,c: integer;
    m: array[0..nmax] of extended;
    b: boolean;
    begin
    c:=0;
    for i:=1 to n do for j:=1 to n do
        begin
        b:=FALSE;
        m[c]:=a[i,j];
        for k:=0 to c-1 do b:=(b)or(m[c]=m[k]);
        if not b then inc(c);
        end;
    //теперь в переменной "c" лежит
    //искомое кол-во неповторяющихся элементов,
    //выводим его как-нибудь.
    end;
 

 
А вообще какая-то кривая идея пихать счетные процедуры-функции прямо в обработчики кнопок...

Всего записей: 2946 | Зарегистр. 09-10-2008 | Отправлено: 23:46 12-12-2014 | Исправлено: dimitriy7, 23:47 12-12-2014
mmotop20oo12



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

Цитата:
А вообще какая-то кривая идея пихать счетные процедуры-функции прямо в обработчики кнопок.

а можно сделать, так, что бы все высчитало в другой процедуре - функции, а потом только на "бутонклик" вывело на вывод?
 
Добавлено:
и конечно же спасибо вам огромное за помощь, все сработало

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 10:44 13-12-2014
landy



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

Цитата:
а можно сделать, так, что бы все высчитало в другой процедуре - функции, а потом только на "бутонклик" вывело на вывод?  

нужно - заводишь отдельную процедуру, описывая её руками в заголовке класса (аналогично соседним методам), а в методе Button2Click её вызываешь.

Всего записей: 576 | Зарегистр. 17-01-2003 | Отправлено: 14:14 13-12-2014
mmotop20oo12



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
да спасибо еще раз, но вот я встретился с такой проблемой. и мне не приходит в голову как ее решить... Суть в том что я заношу в "edit1" число и по этому числу создается матрица рандомных чисел. Пример вожу в ячейку 4 и создается рандомный массив из 4х элементов. Так вот в чем проблемма:  
 x:=StrToFloat(Edit1.Text); //тут я заношу значение с ячейки в переменную Х ип требует обязательно extended (без понятия почему) но вот для массива нужен счетчик, а он работает только с integer числами и работать вот так:  
 for i:= 1 to x do
 begin a[i]:= random (10);
начисто отказывается...
и тут я запутался. Прошу вашей помощи, а именно: как мне использовать введенные с ячейки числа для счетчика.
И еще: как мне вывести то элементы массива в Memo 1? (хоть как в столбик или в строку(но лучше в строку конечно)) спасибо

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 20:02 14-12-2014 | Исправлено: mmotop20oo12, 20:14 14-12-2014
dimitriy7



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

Цитата:
как мне использовать введенные с ячейки числа для счетчика


Код:
for i:= 1 to trunc(x) do
 

Всего записей: 2946 | Зарегистр. 09-10-2008 | Отправлено: 20:13 14-12-2014
mmotop20oo12



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
dimitriy7
вы все на столько просто... Я видел эту функцию и пытался записать так : j:= trunk(x); и потом начитать for i:=1 to j do но ставило ошибку, а до такого у меня не доходила голова..., спасибо, но что на счет вывода массива? Еще у меня получилось вывести массив, НО в столбик. Что нужно написать что бы вывести в строчку массив. Я писал так:  
for I:= 1 to trunc (x) do begin
 Memo1.Lines.Add(FloatToStrF(a[i],ffFixed,8,2));

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 20:51 14-12-2014
ALeXkRU



Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mmotop20oo12
ну так, ты и выводишь каждое значение отдельной строкой..  
Ты сначала собери все значения в одну строку (конкатенацией) в цикле, а потом уже выводи получившуюся строку через Lines.Add (один раз! а не в цикле)

Всего записей: 11795 | Зарегистр. 03-12-2003 | Отправлено: 21:19 14-12-2014
landy



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

Цитата:
спасибо, но что на счет вывода массива?

  используй TStringList для отображения.

Всего записей: 576 | Зарегистр. 17-01-2003 | Отправлено: 10:47 15-12-2014
mmotop20oo12



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
да, я понял и сделал так:

Код:
 
for i:= 1 to x do begin
s:=s+char(a[i]);
end;
memo1.lines.add(s);
 

но почемуто при вычислении в memo выводит просто пустую строку, что делать? (перепроверил, выводит но почемуто все символы невидемы. Если вставить s+'4' то выведет 4ки)
решить смог, но по-тупому... оформил через case (если элемент равен 1 и так до 9 то s:=s + '1..9', но хочется узанть как же мне сделать так чтобы консоль смогла отобразить это более практичным путем.

Цитата:
 используй tstringlist для отображения  

что за тип? и куда применить?

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 12:25 15-12-2014 | Исправлено: mmotop20oo12, 12:41 15-12-2014
landy



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

Цитата:
что за тип? и куда применить

  Сорри, машинально написал вместо TStringGrid. Это визуальный компонент как раз для отображения двумерных массивов на форме.
 
 
 
Добавлено:

Цитата:
перепроверил, выводит но почемуто все символы невидемы

   Это потому, что нужно писать:
s:=s+inttostr(a[i]);

Всего записей: 576 | Зарегистр. 17-01-2003 | Отправлено: 15:50 15-12-2014 | Исправлено: landy, 15:54 15-12-2014
mmotop20oo12



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
да, спасибо вам, я это на учебе узнал (препод подсказал, не тот который алгоритмезацию ведет). про TStringGrid я знаю, но по заданию я не должен был использовать таблицу. Без вас я бы мучался над этим очень долго, СПАСИБО вам большое. И еще где можно проверить статус аккаунта: вот я типо junior member, а как дальше продвигаться?

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 20:30 15-12-2014 | Исправлено: mmotop20oo12, 20:35 15-12-2014
landy



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

Цитата:
вот я типо junior member, а как дальше продвигаться?

  Чем больше постов - тем  больше мембер

Всего записей: 576 | Зарегистр. 17-01-2003 | Отправлено: 22:46 15-12-2014
mmotop20oo12



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Здравствуйте. возник вопрос с выводом массива, нашел такой вариант
for I:= 1 to n do begin
for j:= 1 to n do  
write (mas[i,j]);
writeln;
end;
я тут подумал, ведь 1ый индекс массива это строки, 2ой (j) - столбцы, тогда по счетчик вначале на mas[1 1] потом mas [1 2] и по циклу должно с начало написать элемент массива write (mas[i,j]);, а потом просто перевести курсор writeln;, но почемуто выводит делает все правильно: заполнит сначало 1ую строку, а потом идет на 2ую...Объясните пожалуйста в чем тут дела или я чтото не понимаю

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 12:12 18-12-2014
MERCURY127



Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
mmotop20oo12, код эквивалентен  
for I:= 1 to n do  
begin  
    for j:= 1 to n do  
    begin  
        write (mas[i,j]);
    end
    writeln;  
end
 
второй цикл выполняет только одну строчку write, до writeln он не доходит. если бы было явно написано
for I:= 1 to n do  
begin  
    for j:= 1 to n do  
    begin  
        write (mas[i,j]);
        writeln;  
    end
end
то было бы как ты написал.

Всего записей: 11564 | Зарегистр. 03-08-2008 | Отправлено: 12:20 18-12-2014
mmotop20oo12



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
ааа, все я схавтил, ведь если после for нету бегина, то он выполнит только 1 оператор, все спасибо, просветлен

Всего записей: 327 | Зарегистр. 10-06-2014 | Отправлено: 12:22 18-12-2014 | Исправлено: mmotop20oo12, 12:28 18-12-2014
xpin2013



Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Вопросик, мне нужна процедура с директивой Interrupt. Мне обязательно все регистры объявлять в параметрах или нет. Мне не нужны всякие ES и DS, я их не меняю. Но я вешаю INT 21h, и мне нужно отдавать резулт. Спасибо.

Всего записей: 291 | Зарегистр. 16-01-2014 | Отправлено: 12:29 18-12-2014
Открыть новую тему     Написать ответ в эту тему

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