Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на языке Pascal


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный ХОСТИНГ на базе Linux x64 и Windows x64

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

lamed
Статус: Профессионал
Рейтинг: 2682
∙ повысить рейтинг »
Boriss
Статус: Академик
Рейтинг: 2366
∙ повысить рейтинг »
star9491
Статус: Профессионал
Рейтинг: 2062
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / Pascal (Паскаль)

Номер выпуска:1090
Дата выхода:26.05.2010, 16:30
Администратор рассылки:Boriss, Академик
Подписчиков / экспертов:224 / 180
Вопросов / ответов:1 / 1

Вопрос № 178530: Здравствуйте. Задача по комбинаторике. В среде Turbo Pascal написать программу (исп. процедуры и функции) разгадки числового ребуса СССР=Р^Ф....



Вопрос № 178530:

Здравствуйте. Задача по комбинаторике. В среде Turbo Pascal написать программу (исп. процедуры и функции) разгадки числового ребуса СССР=Р^Ф.

Отправлен: 20.05.2010, 20:41
Вопрос задал: воронова любовь, Посетитель
Всего ответов: 1
Страница вопроса »


Отвечает lamed, Профессионал :
Здравствуйте, воронова любовь! Программа проверялась на Turbo 7 и ABC. Идея решения и комментарии в тексте
Результат работы: 7776=6^5
Код:

program p178530;
{ Программа - разгадка числового ребуса СССР=Р^Ф }
{ Идея решения: перебрать все четырехзначные числа вида XXXY и выяснить,
не является ли какое-то из них степенью Y. }
var
i, j: integer; { счетчики начальных и последней цифр }
tested: integer; { тестируемое число }
r: integer; { показатель степени (или минус единица) }

function TryPower(val: LongInt; n: integer): integer;
{ Если число n=1 или val не является степенью числа n, возвращается -1 }
{ В противном случае возвращается показатель степени }
var
p: LongInt;
i: integer;
begi n
if n=1 then
TryPower := -1
else
begin
p:= n;
i:= 1;
while p<val do
begin
p:=p*n;
i:= i+1;
end;
if p=val then { n^i==val }
TryPower := i
else
TryPower := -1;
end;
end; { TryPower }

begin { main }
for i:= 1 to 9 do { начальные цифры }
for j:= 1 to 9 do { последняя цифра }
if j<>i then begin
{ последняя цифра отличается от первой }
tested := 1110*i+j;
r := TryPower(tested, j);
if r in [2..9] then
writeln(tested, '=', j, '^', r);
end;
readln;
end.

Ответ отправил: lamed, Профессионал
Ответ отправлен: 21.05.2010, 13:30
Номер ответа: 261544

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 261544 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:

  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2010.6.16 от 26.05.2010

    В избранное