题目信息:求两个大数之间的斐波那契数的个数(C++/JAVA)

pid=1316">http://acm.hdu.edu.cn/showproblem.php?

pid=1316

这里给出java代码和c++代码

C++:AC代码

#include<iostream>

#include<string>

using namespace std;

string add(string s1,string s2){//字符串模拟大数加法

    string s;

    int len1,len2;

    len1=s1.size()-1; len2=s2.size()-1;

    int i=0,flag=0;

    while(len1>-1&&len2>-1){

        int sum=flag+(s1[len1--]-'0')+(s2[len2--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    while(len1>-1){

        int sum=flag+(s1[len1--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    while(len2>-1){

        int sum=flag+(s2[len2--]-'0');

        s+=char ((sum)%10+'0');

        flag=sum/10;

    }

    if(flag) s+=char ('0'+flag);

    //cout<<s<<endl;

    for(int i=0;i<s.size()/2;i++){

        char c=s[i];

        s[i]=s[s.size()-i-1];

        s[s.size()-i-1]=c;

    }

    return s;

}

int compareto(string s,string s1){//模拟大数(字符串)比較



    int j,i,len=s.size(),len1=s1.size();

    for(i=0;s[i]=='0';i++);//去掉前导0

    for(j=0;s1[j]=='0';j++);//去掉前导0

    if(len-i>len1-j) return 1;

    else if(len-i<len1-j) return -1;

    else for(;s[i]==s1[j]&&i<len;i++,j++);

    if(s[i]>s1[j]) return 1;//s>s1

    if(s[i]<s1[j]) return -1;//s<s1

    return 0;

}

string s[501];

int main()

{

    string a,b;

    s[1]="1"; s[2]="2";

    for(int i=3;i<=500;i++){

        s[i]=add(s[i-1],s[i-2]);

        //if(i<10) cout<<s[i]<<endl;

    }

    while(cin>>a>>b){

        if(a=="0"&&b=="0") break;

        //cout<<compareto(a,b)<<endl;

        int sum=0;

        for(int i=1;i<=500;i++){

            if(compareto(s[i],a)>=0&&compareto(s[i],b)<=0){

                sum++;

            }

        }

        cout<<sum<<endl;

    }



    return 0;

}



java代码:

import java.math.BigInteger;

import java.util.Scanner;



public class Main {



    public static void main(String[] args) {

        BigInteger a,b;

        BigInteger s[] = new BigInteger[1501];

        s[0]=BigInteger.ZERO;

        s[1]=BigInteger.ONE;

        s[2]=BigInteger.valueOf(2);

        for(int i=3;i<=1500;i++){

            s[i]=s[i-1].add(s[i-2]);

        }

        //System.out.println(s[1500]);

        Scanner sc = new Scanner(System.in);

        while(sc.hasNext()){

            a=sc.nextBigInteger();

            b=sc.nextBigInteger();

            if(a.add(b).compareTo(BigInteger.ZERO)==0) break;

            int cnt=0;

            //提高程序的鲁棒性

            if(a.compareTo(b)>0){

                BigInteger tmp=a;

                a=b;

                b=tmp;

            }

            for(int i=1;i<=1500;i++){

                if(s[i].compareTo(a)>=0&&s[i].compareTo(b)<=0){

                    cnt++;

                }

            }

            System.out.println(cnt);

        }



    }

}

hdu1316(大数的斐波那契数)的更多相关文章

  1. HDU1316(求区间斐波那契数的个数)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1316 题意:给两个数a和b,其中它们可能很大,最大到10^100,然后求去区间[a,b]内有多少个fib数 ...

  2. UVA 11582 Colossal Fibonacci Numbers! 大斐波那契数

    大致题意:输入两个非负整数a,b和正整数n.计算f(a^b)%n.其中f[0]=f[1]=1, f[i+2]=f[i+1]+f[i]. 即计算大斐波那契数再取模. 一开始看到大斐波那契数,就想到了矩阵 ...

  3. 斐波那契数[XDU1049]

    Problem 1049 - 斐波那契数 Time Limit: 1000MS   Memory Limit: 65536KB   Difficulty: Total Submit: 1673  Ac ...

  4. C++求斐波那契数

    题目内容:斐波那契数定义为:f(0)=0,f(1)=1,f(n)=f(n-1)+f(n-2)(n>1且n为整数) 如果写出菲氏数列,则应该是: 0 1 1 2 3 5 8 13 21 34 …… ...

  5. Project Euler 104:Pandigital Fibonacci ends 两端为全数字的斐波那契数

    Pandigital Fibonacci ends The Fibonacci sequence is defined by the recurrence relation: F[n] = F[n-1 ...

  6. DP:斐波纳契数

    题目:输出第 n 个斐波纳契数(Fibonacci) 方法一.简单递归 这个就不说了,小n怡情,大n伤身啊……当n=40的时候,就明显感觉到卡了,不是一般的慢. //输出第n个 Fibonacci 数 ...

  7. HDU4549 M斐波那契数

    M斐波那契数列 题目分析: M斐波那契数列F[n]是一种整数数列,它的定义例如以下: F[0] = a F[1] = b F[n] = F[n-1] * F[n-2] ( n > 1 ) 如今给 ...

  8. HDU 5914 Triangle(打表——斐波那契数的应用)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5914 Problem Description Mr. Frog has n sticks, whos ...

  9. [Swift]LeetCode509. 斐波那契数 | Fibonacci Number

    The Fibonacci numbers, commonly denoted F(n) form a sequence, called the Fibonacci sequence, such th ...

随机推荐

  1. Android视频截图

    本文介绍如何获取视频中某个时间点的数据 调用以下方法即可,特别注意,在获取图片时的参数单位为微秒,不是毫秒 如果错用了毫秒会一直获取第一帧的画面 /** * 获取某个时间点的帧图片 * * @para ...

  2. 探索java世界中的日志奥秘

                    java日志简单介绍 对于一个应用程序来说日志记录是必不可少的一部分.线上问题追踪,基于日志的业务逻辑统计分析等都离不日志.JAVA领域存在多种日志框架,目前常用的日志 ...

  3. JS——正则

    正则的声明: 1.构造函数:var 变量名= new RegExp(/表达式/); 2.直接量:var 变量名= /表达式/; test()方法: 1.正则对象方法,检测测试字符串是否符合该规则,返回 ...

  4. SPPNet论文翻译-空间金字塔池化Spatial Pyramid Pooling in Deep Convolutional Networks for Visual Recognition

    http://www.dengfanxin.cn/?p=403 原文地址 我对物体检测的一篇重要著作SPPNet的论文的主要部分进行了翻译工作.SPPNet的初衷非常明晰,就是希望网络对输入的尺寸更加 ...

  5. javascript的严格模式:use strict

    ECMAscript 5添加的运行模式,禁止一些非标准.不安全的操作. <script> "use strict"; console.log("这是严格模式. ...

  6. 【sqli-labs】 less58 GET -Challenge -Double Query -5 queries allowed -Variation1 (GET型 挑战 双查询 只允许5次查询 变化1)

    单引号闭合成功,但是union select结果不对 http://192.168.136.128/sqli-labs-master/Less-58/?id=0' union select 1,2,3 ...

  7. [ECharts]"echarts/config" is not exists

    今天在给Echarts折线图中的数据点增加点击事件的时候总是出现一个 Uncaught Error: [MODULE_MISS]"echarts/config" is not ex ...

  8. Replacing Threads with Dispatch Queues

    Replacing Threads with Dispatch Queues To understand how you might replace threads with dispatch que ...

  9. 北京Linux运维培训怎么选?

    北京的地理优势和经济优势基本无需多言,作为全国机会最多的地方,吸引了无数的北漂前赴后继.作为中国互联网中心之一,北京有海量的运维岗位正在等待大家淘金.北京的Linux云计算培训业蓬勃发展. 云计算早已 ...

  10. tomcat 编码设置

    在Tomcat8.0之前的版本,如果你要向服务器提交中文是需要转码的(如果你没有修改server.xml中的默认编码),因为8.0之前Tomcat的默认编码为ISO8859-1. POST方式提交 r ...