Написать в VBA, используя подпрограмму: Натуральное число, в записи которого n цифр,...

0 интересует 0 не интересует
147 просмотров

Написать в VBA, используя подпрограмму:
Натуральное число, в записи которого n цифр, называется числом Амстронга, если сумма его цифр, возведенных в степень n равна самому числу. Найти все эти числа от 1 до k.


спросил от Начинающий (214 баллов) в категории Информатика
оставил комментарий от Архангел (142k баллов)
0 0

У Вас неверное определение числа Армстронга. Не "сумма цифр, возведенная в степень, а сумма цифр, возведенных в степень.

оставил комментарий от Архангел (142k баллов)
0 0

Т.е. не (1+2+3)^3, а 1^2+2^3+3^3

оставил комментарий от Начинающий (214 баллов)
0 0

не я писал задачу... поэтому вот такие бывают ошибки

оставил комментарий от Архангел (142k баллов)
0 0

Верю, но автор вопроса для нас - Вы...

оставил комментарий от Архангел (142k баллов)
0 0

Поэтому либо оставляйте так и тогда решение будет не для числе Армстронга, либо исправляйте.

оставил комментарий от Начинающий (214 баллов)
0 0

Исправил

1 Ответ
0 интересует 0 не интересует
ответил от Архангел (142k баллов)
 
Лучший ответ

Function IsArmstrong(m As Long) As Boolean
    Dim s As Long, n As Integer, i As Integer, m1 As Long
    Dim d(1 To 15) As Long
    m1 = m: n = 0
    Do While m1 > 0
        n = n + 1
        d(n) = m1 Mod 10
        m1 = Int(m1 / 10)
    Loop
    s = 0
    For i = 1 To n
        s = s + d(i) ^ n
    Next i
    IsArmstrong = (s = m)
End Function

Sub Test()
    Dim k As Long, i As Long, j As Integer
    Cells.Clear
    k = CLng(InputBox("Введите значение k"))
    j = 1
    For i = 0 To k
        If IsArmstrong(i) Then
            Cells(j, 1) = i
            j = j + 1
        End If
    Next i
End Sub


оставил комментарий от Архангел (142k баллов)
0 0

Результат выводится на активный лист рабочей книги

...