码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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数的个数。

  • 相关阅读:
    Redis学习笔记:Redis中的三种新数据类型
    嵌入式分享合集109
    [笔记]JavaScript 实现按钮拖拽效果
    Python采集剧本杀店家数据信息,做可视化演示
    Windows 11家庭中文版安装安卓子系统
    Flutter实战--用Getx组织项目结构
    STL——list
    allegro中怎样制作和添加logo
    Android 内容提供者和内容观察者:数据共享和实时更新的完美组合
    .NET微信网页开发之通过UnionID机制解决多应用用户帐号统一问题
  • 原文地址:https://blog.csdn.net/huang1xiao1sheng/article/details/140462875
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号