• 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数的个数。

  • 相关阅读:
    快速上手 git
    LVS之DR模式(最常见的LVS负载方式,直接路由模式)
    代码中的软件工程:正则表达式十步通关
    docker 部署es 集群 elasticsearch
    2022.8.8考试区域链接(district)题解
    八个提升编程体验的VS Code插件
    线性代数的一些知识点
    Git 仓库代码太大clone不下来
    初识Nacos
    简单的聊一聊Vue中如何使用 Ref 和 Reactive 声明响应式数据
  • 原文地址:https://blog.csdn.net/huang1xiao1sheng/article/details/140462875