Advertisement
xDefo

Crittografia LWF(1)

May 6th, 2017
155
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.23 KB | None | 0 0
  1. // lwf.cpp : definisce il punto di ingresso dell'applicazione console.
  2. //
  3.  
  4. #include "stdafx.h"
  5. #include <iostream>
  6. #include <stdio.h>
  7. #include <vector>
  8.  
  9. using namespace std;
  10.  
  11. int N;
  12. int k = 0;
  13. vector <int> sequenza;
  14. vector <int> fibo;
  15.  
  16. int fibonacci(int i)
  17. {
  18.     if (i == 0)
  19.     {
  20.         return 0;
  21.     }
  22.     else if (i == 1)
  23.     {
  24.         return 1;
  25.     }
  26.     else
  27.     {
  28.         return fibonacci(i - 1) + fibonacci(i - 2);
  29.     }
  30. }
  31.  
  32. void crea_Sequenza()
  33. {
  34.     sequenza[k - 1] = 1;
  35.     N -= fibo[k-1];
  36.     while (N != 0)
  37.     {
  38.         for (int i = 0; i < k; i++)
  39.         {
  40.             if (fibo[i] > N)
  41.             {
  42.                 sequenza[i - 1] = 1;
  43.                 N -= fibo[i - 1];
  44.                 break;
  45.             }
  46.         }
  47.     }
  48. }
  49.  
  50. void crea_fibo() // riempie un vector con gli elementi della succesione di fibonacci fino a k
  51. {
  52.     for (int i = 0; i < k+1; i++)
  53.     {
  54.         fibo.push_back(fibonacci(i));
  55.     }
  56.     fibo.erase(fibo.begin());
  57.     k = fibo.size();
  58. }
  59.  
  60. int main()
  61. {
  62.     freopen("input.txt", "r", stdin);
  63.     freopen("output.txt", "w", stdout);
  64.     cin >> N;
  65.     while (fibonacci(k) <= N)
  66.     {
  67.         k += 1;
  68.     }
  69.     k -= 1;
  70.     crea_fibo();
  71.     sequenza.resize(k);
  72.     crea_Sequenza();
  73.     k = sequenza.size();
  74.     for (int i = 0; i < k; i++)
  75.     {
  76.         cout << sequenza.at(i);
  77.     }
  78.     cout << "\n";
  79.     for (int i = 0; i < k; i++)
  80.     {
  81.         cout <<fibo.at(i);
  82.     }
  83.     return 0;
  84. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement