Есть 2 функции, находящие n-ное число Фибоначчи. Первое находит через фор-лу Бине O(Log N), второе через метод итераций O(n).
static double SQRT5 = Math.Sqrt(5);
static double PHI = (SQRT5 + 1) / 2;
public static int Bine(int n)
{
return (int)(Math.Pow(PHI, n) / SQRT5 + 0.5);
}
static long[] NumbersFibonacci = new long[35];
public static void Iteracii(int n)
{
NumbersFibonacci[0] = 0;
NumbersFibonacci[1] = 1;
for (int i = 1; i < n - 1; i++)
{
NumbersFibonacci[i + 1] = NumbersFibonacci[i] + NumbersFibonacci[i - 1];
}
}
Но для нахождения 35 члена последовательности фор-ла Бине работает по времени хуже, чем метод итераций. При этом если вместо 35 написать достаточно большое число, например 1000000 (чисто в целях эксперимента), то время работы для фор-лы Бине не изменится, но для метода итераций возрастёт в несколько раз.
В связи с этим вопрос, сложность Math.Pow, который используется в фор-ле Бине (из-за которого такое время работы) на самом деле const, и если да, то как это доказать?
Очень просто доказать, что существует алгоритм работающий за константное время при определенных условиях, а значит в библиотечной функции скорее всего будет использован как минимум не худший алгоритм.
Существует алгоритм быстрого возведения в степень он требует O(n)
операций умножения, где n
- количество бит показателя.
Каждая операция умножения даже для не самого оптимального алгоритма требует O(n*m)
элементарных операций, где n
и m
- количество бит в соответствующих числах.
Для каких нибудь бесконечных числовых типов константой тут и не пахнет, но в вашем случае используются типы с фиксированным количеством бит - double
и int
, а значит все эти n
и m
превращаются в тыкву – константы, следовательно и сам алгоритм возможно реализовать за O(1)
.
Ваш алгоритм способен работать только с очень небольшими аргументами, так вы еще и ограничиваете результат интом. Если программа действительно должна иметь возможность вычислять F1000000 как в примере, имейте в виду, что результат будет занимать сотни тысяч бит и без неограниченных числовых типов вам не обойтись, а значит и константной сложности ждать не стоит.
Виртуальный выделенный сервер (VDS) становится отличным выбором
Всем привет, суть проблемы то что я делаю "Регистрацию" для этого я делаю проверки что бы небыло одинаковых логинов делаю проверку:
Постоянно сталкиваюсь с ошибкой :
Через fetch в файл сorephp отправляется action, который равен 'login', а так же email и epass
Во время нажатия кнопки Start Server загорается зеленый круг на Apache,через 1 секунду уже на MySQL,затем с Apache пропадает зеленый круг и остается только...