• 1143 多少个Fibonacci数


    首先,我们需要生成一个Fibonacci数列,直到其值超过10^100。由于Fibonacci数列的性质,我们知道这个数列的长度不会超过500。

    然后,对于每一对输入的a和b,我们在生成的Fibonacci数列中查找在a和b之间的数的个数。这可以通过二分查找来实现,因为Fibonacci数列是有序的。

    以下是对应的C++代码:

    1. #include
    2. #include
    3. #include
    4. using namespace std;
    5. vector fibs;
    6. // 大数加法
    7. string add(string num1, string num2) {
    8.     string res;
    9.     int i = num1.size() - 1;
    10.     int j = num2.size() - 1;
    11.     int carry = 0;
    12.     while(i >= 0 || j >= 0 || carry != 0) {
    13.         int sum = carry;
    14.         if(i >= 0) sum += num1[i--] - '0';
    15.         if(j >= 0) sum += num2[j--] - '0';
    16.         res += to_string(sum % 10);
    17.         carry = sum / 10;
    18.     }
    19.     reverse(res.begin(), res.end());
    20.     return res;
    21. }
    22. // 大数比较
    23. bool compare(string num1, string num2) {
    24.     if(num1.size() != num2.size()) return num1.size() < num2.size();
    25.     return num1 < num2;
    26. }
    27. // 生成Fibonacci数列
    28. void generateFibonacci() {
    29.     fibs.push_back("1");
    30.     fibs.push_back("2");
    31.     while(true) {
    32.         string fib = add(fibs[fibs.size() - 1], fibs[fibs.size() - 2]);
    33.         if(compare(fib, string(101, '0'))) fibs.push_back(fib);
    34.         else break;
    35.     }
    36. }
    37. int main() {
    38.     generateFibonacci();
    39.     string a, b;
    40.     while(cin >> a >> b) {
    41.         if(a == "0" && b == "0") break;
    42.         int count = upper_bound(fibs.begin(), fibs.end(), b, compare) - lower_bound(fibs.begin(), fibs.end(), a, compare);
    43.         cout << count << endl;
    44.     }
    45.     return 0;
    46. }

    这段代码首先生成了一个Fibonacci数列,然后对于每一对输入的a和b,它计算并输出在a和b之间的Fibonacci数的个数。

  • 相关阅读:
    首次去中心化抢劫?近2亿美元损失:跨链桥Nomad 被攻击事件分析
    RabbitMq
    【Shell脚本入门】
    Metasploit
    【C语言基础】函数的参数是指针
    Java的XWPFTemplate工具类导出word.docx的使用
    模拟滤波器的基础知识和设计
    一篇文章让你理解TCP协议,搭建TCP flood攻击实验以及了解其防御原理
    2019 ccpc女生赛 Tree
    阈值同态加密在隐私计算中的应用:解读
  • 原文地址:https://blog.csdn.net/huang1xiao1sheng/article/details/140462875