С Новым годом! Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
4 / 4 / 0
Регистрация: 26.09.2009
Сообщений: 45

Рекурсия: введенные числа распечатать в обратном порядке

08.11.2009, 14:31. Показов 1574. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать рекурсивную процедуру, которая считывает вводимые с клавиатуры числа до тех пор, пока не будет обнаружен нуль. Затем введенные числа распечатываются в обратном порядке. Нуль тоже печатать.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.11.2009, 14:31
Ответы с готовыми решениями:

Распечатать элементы массива в обратном порядке по 4 числа в строке
Дан массив целых чисел, состоящий из 44 целых элементов из диапазона от -45 до 55,введенных произвольным образом: 1)Распечатайте...

Рекурсия: введенные числа распечатать в обратном порядке
Написать рекурсивную процедуру, которая считывает вводимые с клавиатуры числа до тех пор, пока не будет обнаружен нуль. Затем введенные...

Распечатать числа в обратном порядке по 6 чисел в строке
1) В прямоугольной матрце, размерностью n*m, заполненной случайным образом числами из промежутка , найти сумму и количество элементов...

9
 Аватар для lexus_ilia
3067 / 727 / 69
Регистрация: 24.09.2008
Сообщений: 1,531
09.11.2009, 03:00
Простенькая задачка...
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Program xa;
uses
  crt;
 
procedure ctek(c:char);
begin
  c:=readkey;
  if c<>'0' then
    ctek(c);
   Write(c);
end;
 
var
  c:char;
 
begin
  clrscr;
  Writeln('VVodute cumBoLbl');
  ctek(c);
  readln;
end.
0
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
09.11.2009, 11:22
lexus_ilia, Ты не прав. У тебя выводится только последний символ перед нолем, а по условию, если оно верное, нужно вывести все числа начиная с ноля в обратном порядке. Ты правильно назвал процедуру Стек.
0
 Аватар для lexus_ilia
3067 / 727 / 69
Регистрация: 24.09.2008
Сообщений: 1,531
10.11.2009, 01:30
Puporev, хм, ввожу такую строку "123467890" на экране выводит "0987654321", что неправильно?
Я поэтому процедуру так и назвал, т.к. её работа похожа на работу стека.
0
Retired
7727 / 2559 / 671
Регистрация: 17.10.2009
Сообщений: 5,100
10.11.2009, 01:48
Puporev, да действительно 1234567890 дает 0987654321 тут все верно... я тоже протестил...
0
 Аватар для lexus_ilia
3067 / 727 / 69
Регистрация: 24.09.2008
Сообщений: 1,531
10.11.2009, 01:59
Как бы может кому-то интересно но рекурсия сама работает со стеком в памяти, если вы встречали сообщение из работы рекурсии "Stack overflow...", то это означало что стек который заполняла Ваша рекурсия переполнился и вывелось сообщение об ошибке.

В данной программе что получается:
1)Вызывается процедура ctek
2)Ожидает нажатия клавиши, допустим нажата "6", происходит проверка не равно ли это '0', если не равно, то значение "6" заносится в стек и вызывается процедура ctek
3)всё тоже самое что и в п.2, ввели например "4"
4)всё тоже самое что и в п.2, ввели "0", процедура не вызывает саму себя, а начинает как бы это сказать "подниматься вверх", т.е. печатается "0", происходит возврат в предыдущий вызов, где значение переменной с берётся из стека и удаляется из него, и выводится, и так происходит пока не опустеет стек.
4.1) на экране напечатает "046"
5)ожидание нажатия клавиши и выход из программы.
1
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
10.11.2009, 06:27
lexus_ilia, Прошу прощения, но в первый раз у меня почему-то действительно выводило только последний символ, сам удивился, а сегодня выводит все нормально.
0
 Аватар для lexus_ilia
3067 / 727 / 69
Регистрация: 24.09.2008
Сообщений: 1,531
10.11.2009, 14:50
Puporev, Никаких проблем, я всё понимаю, у всех бывает.
0
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
10.11.2009, 14:54
У меня бывает с Crt иногда глюки, нажмешь клавишу, символа нет, нажмешь еще раз-два, появится.
0
10.11.2009, 17:04

Не по теме:

Цитата Сообщение от Puporev Посмотреть сообщение
У меня бывает с Crt иногда глюки, нажмешь клавишу
а у меня наоборот хоть без crt, хоть с ним, не все символы на экране выводятся, но я решил эти проблемы clrscr;(с ним все железно выводит)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.11.2009, 17:04
Помогаю со студенческими работами здесь

Рекурсия. Вывести в обратном порядке цифры целого положительного числа n
Составить рекурсивную процедуру,которая выдает на печать в обратном порядке цифры целого положительного числа n

Введенные числа распечатать в обратном порядке
Написать рекурсивную процедуру, которая считывает вводимые с клавиатуры числа до тех пор, пока не будет обнаружен нуль. Затем введенные...

Используя стек вывести числа введенные пользователем в обратном порядке.
помогите плиз решить задачу......Используя стек вывести числа введенные пользователем в обратном порядке (элемент стека – число; числа...

Используя стек вывести числа введенные пользователем в обратном порядке элемент стека – число
помогите плиз решить ..Используя стек вывести числа введенные пользователем в обратном порядке элемент стека – число; числа введенные...

Вывести числа в обратном порядке(рекурсия)
Здравствуйте, есть задача в которой нужно вывести числа в обратном порядке. Сначала вводится количество элементов , а затем сами...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru