С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
WaK
1 / 1 / 0
Регистрация: 14.04.2013
Сообщений: 39
#1

Найти номер заданного числа Фибоначи - C++

05.04.2016, 13:44. Просмотров 258. Ответов 4
Метки нет (Все метки)

Дано положительное число А. Найти номер к такого числа Фибоначи Xk, что Xk-1≤A<Xk
Числа Фибоначи X1=1, X2=1, X3=2,....Xk=Xk-1+Xk-2
Протестировать задачу для значений A 4, 51, 21. Результат вывести на экран
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.04.2016, 13:44
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти номер заданного числа Фибоначи (C++):

Найти номер первого вхождения заданного числа в массиве - C++
1. Вычислить среднее арифметическое квадратов положительных элементов. 2. Определить количество элементов, имеющих четные порядковые...

Дан массив, упорядоченный по убыванию. Найти номер первого элемента, меньшего заданного числа a - C++
Дан массив, упорядоченный по убыванию. Найти номер первого элемента, меньшего заданного числа a.

Найти первую и последнюю цифры заданного числа; найти сумму цифр заданного числа - C++
Помогите решить в С++ 2.1 Дано натуральное число: − найти первую и последнюю цифры числа; − верно ли, что сумма цифр данного числа...

Найти номер первого максимального элемента среди отрицательных элементов, расположенных до первого элемента, большего заданного числа Т - C++
Написать собственную функцию для работы с одномерным динамическим массивом, заданным указателем. Алгоритмы решения всех подзадач, включая...

Дан массив упорядоченных по возрастанию целых чисел. разработать алгоритм бинарного поиска заданного числа, результат номер искомого числа или 0 если - C++
помогите решить задачу: Дан массив упорядоченных по возрастанию целых чисел. разработать алгоритм бинарного поиска заданного числа,...

Вывести номер первого числа в наборе большего заданного - C++
Дано целое число K и набор ненулевых целых чисел; признак его завершения — число 0. Вывести номер первого числа в наборе, большего K ...

4
TimeTwo
71 / 71 / 32
Регистрация: 29.11.2009
Сообщений: 326
05.04.2016, 13:53 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
WaK, МИРЭА РТС лаба 1 вариант 3 задание 3 Автор Беляева А.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <iostream>
#include <math.h>
using namespace std;
 
int fibo(int n)  //рекурсивная функция
{
    if((n == 0)||(n == 1)){
        return n;
    }else{ 
        return fibo(n-1)+fibo(n-2); //в этой строке вызываем функцию рекурсивно
    }
}
 
int main ()
{
    int a, result1, fib1, fib2;
    cout<<"enter number: ";
    cin>>a;
    for(int i=1;i<500;i++){
        fib1 = fibo(i-1);
        fib2 = fibo(i);
        if ((fib1 <= a)&&(a < fib2)){
            cout<<"fibonachi number = "<<i<<endl;
            break;
        }
    }
    return 0;
}
1
mike1806
0 / 0 / 0
Регистрация: 18.04.2017
Сообщений: 26
23.04.2017, 13:30 #3
TimeTwo, Прошу прощения за вопрос, а у вас нет еще кодов для задач из этих лаб?
0
TimeTwo
71 / 71 / 32
Регистрация: 29.11.2009
Сообщений: 326
23.10.2017, 15:36 #4
Вот, все что есть.
Лучше поздно чем никогда...
0
Вложения
Тип файла: rar stud.rar (338.7 Кб, 2 просмотров)
Catstail
Модератор
22917 / 11283 / 1834
Регистрация: 12.02.2012
Сообщений: 18,495
23.10.2017, 16:01 #5
TimeTwo, код - полный отстой! 1) параллельная рекурсия при вычислении числа Фибоначчи будет очень сильно тормозить... но 2) в строках 20 и 21 происходит еще одно тупое перевычисление. и 3) - вишенка на торте - цикл до 500 (стр. 19). Если код рассчитан на проверку до 500-го числа, то автору неплохо было бы (на бумажке, на калькуляторе) вычислить 500-е число Фибоначчи. Могу помочь:

F500=139423224561697880139724382870407283950070256587697307264108962948325571622863290691557658876222521294125 Интересно: а) уместится ли это значение в тип int и б) сколько времени программа (даже на C++!) будет его вычислять? В действительности программа либо зациклится, либо упадет из-за переполнения стека.

Не позорь МИРЭА! Вот нормальный код:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <cstdlib>
#include <iostream>
using namespace std;
int cFib(int A)
{
     int t,i=1,c=1,p=1;
     while (1)
     {
          if (A>p && A <=c) return i;
          t=c;
          c=p+c;
          p=t;
          i++;
     }    
}     
int main(int argc, char *argv[])
{
    int A;
    cout << "A=";
    cin >> A;
    cout << "Fib num=" << cFib(A) << endl;
    system("PAUSE");
    return EXIT_SUCCESS;
}
0
23.10.2017, 16:01
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.10.2017, 16:01
Привет! Вот еще темы с ответами:

Найти количество делителей заданного числа n, заданного в диапазоне 1 <= n <= 10^18 - C++
Нужно узнать количество делителей числа N. Но сложность в том что N большое и перебирать все делите не вариант.

Разделить каждую цифру заданного числа на его порядковый номер - C++
Дано число. Разделить каждую цифру числа не его порядковый номер. #include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; int...

Определить номер строки матрицы в которой содержится более одного заданного числа - C++
Дана целочисленная квадратная матрица. Определить: 1)номер строки, в которой содержится более одного заданного числа 2) упорядочить...

числа Фибоначи - C++
1)Определить 40-е число Фибоначи 2)поиск 1-го числа Фибоначи больше заданного числа m 3)Вычисление суммы всех чисел Фибоначи,которое не...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.