Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [C++] Рекурсия. Число Фибоначчи 
:(
    Опции темы
dk88
Дата 9.9.2011, 14:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 9.9.2011

Репутация: нет
Всего: нет



Код


Чему равно количество повторений наиболее часто встречающейся цифры в 2011-м члене ряда Фибоначчи.
заранее спасибки smile 
PM MAIL   Вверх
volatile
Дата 10.9.2011, 13:01 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2107
Регистрация: 7.1.2011

Репутация: 8
Всего: 85



Чаще всего встречается: '1' = 57 раз.

http://liveworkspace.org/code/f972d0b1ac9d...3bcfb46a34d93a2
smile
PM MAIL   Вверх
dk88
Дата 16.9.2011, 00:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 9.9.2011

Репутация: нет
Всего: нет



А можно код на С++?smile
PM MAIL   Вверх
volatile
Дата 16.9.2011, 01:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2107
Регистрация: 7.1.2011

Репутация: 8
Всего: 85



Цитата(dk88 @  16.9.2011,  00:32 Найти цитируемый пост)
А можно код на С++? 

Ссылка выше.
PM MAIL   Вверх
dk88
Дата 16.9.2011, 01:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 3
Регистрация: 9.9.2011

Репутация: нет
Всего: нет



Не могу открыть:(блокирует...можно сюда код?пожалуйстаsmile
PM MAIL   Вверх
volatile
Дата 16.9.2011, 09:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2107
Регистрация: 7.1.2011

Репутация: 8
Всего: 85



Код

#include <iostream>
#include <memory.h>

template <size_t N>
class bignum
{
public:
   bignum ( size_t v = 0 ) { assign ( v ); }

   const bignum & operator = ( size_t v ) { assign ( v ); return * this; }

   void assign ( size_t v )
   {
      memset ( body, 0, N );
      char buf [ 32 ];
      size_t len = sprintf ( buf, "%u", v );
      for ( size_t i = 0; i < len; ++ i )
      {
         body [ i ] = buf [ len - i - 1 ] - '0';
      }
   }

   const bignum & operator += ( const bignum & that )
   {
      char cary = 0;
      for ( size_t i = 0; i < N; ++ i )
      {
         char t = body [ i ] + that.body [ i ] + cary;
         if ( cary = t >= 10 )
            t -= 10;
         body [ i ] = t;
      }
      return * this;
   }

   void print_statistic () const
   {
      int dig [ 10 ] = { 0 };
      bool f_started = 0;
      for ( size_t i = 0; i < N; ++ i )
      {
         size_t r = N - i - 1;
         if ( f_started || body [ r ] || r == 0 )
         {
            f_started = 1;
            dig [ body [ r ] ] ++;
         }
      }
      int imax = 0;
      int total = 0;
      for ( int i = 0; i < 10; ++ i )
      {
         std::cout << "'" << i << "' = " << dig [ i ] << " digits" << std::endl;
         total += dig [ i ];
         if ( dig [ i ] > dig [ imax ] )
            imax = i;
      }
      std::cout << "total: " << total << " digits" << std::endl;
      std::cout << "max is: '" << imax << "' = " << dig [ imax ] << " digits" << std::endl;
   }

   friend std::ostream & operator << ( std::ostream & out, const bignum & num )
   {
      bool f_started = 0;
      for ( size_t i = 0; i < N; ++ i )
      {
         size_t r = N - i - 1;
         if ( f_started || num.body [ r ] || r == 0 )
         {
            f_started = 1;
            out << char (num.body [ r ] + '0');
         }
      }
      return out;
   }

private:
   char body [ N ];
};


// Вычисление числа фибоначчи, правда без рекурсии, так эффективнее
template <size_t N>
void fib ( bignum <N> & result, int num )
{
   bignum <N> a [ 2 ] = { 0, 1 };
   int i = -! num;
   for (; i < num - 1; ++ i )
   {
      a [ i & 1 ] += a [ ( i + 1 ) & 1 ];
   }
   result = a [ ( i + 1 ) & 1 ];
}

void go ( int num )
{
   bignum <500> a;
   fib ( a, num );
   std::cout << "fib(" << num << ")= " << a << std::endl;
   a.print_statistic ();
}

int main ()
{
   go ( 2011 );
}


Это сообщение отредактировал(а) volatile - 16.9.2011, 09:19
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.1172 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.