10 небольшое эссе предложений 10,по памятке:
чтобы безопасно общаться в интернете, помните:
1) общение с незнакомыми людьми допустимо только на сервисах, где вы можете сохранять анонимность.
2) общаюсь не знакомым человеком на анонимном сервисе, никогда не раскрывайте своих данных и не давайте ссылку на свой профиль в социальной сети.
3) публикую что-либо на связь вместе, делайте запись доступна только тем, с кем вы действительно хотите поделиться .
4) время от времени проверяйте список друзей и удаляете из него людей, с которыми больше не общаетесь и не планируете общаться вновь.
/*Простейшая реализация. Подразумевается, что вводятся корректные данные, n вмещается в int, а a и результат - в double. Визуализация зависимости числа операций умножения от степени n для чисел от 0 до 5000 прилагается */
#include <iostream>
double s_pow(double a, int power)
{
if (power == 0)
{
return 1;
}
if (power % 2 == 0)
{
return s_pow(a * a, power / 2);
}
return a * s_pow(a, power - 1);
}
int main()
{
double a;
int n;
std::cin >> a >> n;
std::cout << s_pow(a, n);
return 0;
}
=== Python 3.8.3 ===
def fastExp(b, n):
def even(n):
if n % 2 == 0:
return True
return False
if n == 0:
return 1
if even(n):
#Можно было написать return fastExp(b, b/2) ** 2, но операцию возведения в степень использовать нам запретили.
res = fastExp(b, n/2)
return res*res
return b*fastExp(b, n-1)
def main():
base = float(input())
exp = int(input())
print(fastExp(base, exp))
if __name__ == "__main__":
main()
Предложенные тесты проходит. Сам алгоритм быстрого возведения в степень реализован в виде функции fastExp(b, n)