• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 21, comments - 2, trackbacks - 0, articles - 0

            ZOJ 1828 Fibonacci Numbers

            Posted on 2011-05-22 13:56 acpeng 閱讀(428) 評論(0)  編輯 收藏 引用 所屬分類: ACM程序
            OJ地址:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1828
            f(1) = 1, f(2) = 1, f(n > 2) = f(n - 1) + f(n - 2)。
            輸入n,計算f(n)。f(n)位數小于1000。

            Sample Input

            100


            Sample Output

            354224848179261915075


            基本思路,字符串方式模擬計算過程。簡單題。
             1 /*
             2 計算Fibonacci數列第 n 項
             3 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1828
             4 */
             5 #include<stdio.h>
             6 #include<string.h>
             7 void addstr(char *str1,char *str2,char *str3)
             8 {
             9     int lgth1,lgth2,c,tmp,i,j,k;
            10     char add1num,add2num;
            11     lgth1=(int)strlen(str1);lgth2=(int)strlen(str2);
            12     k=lgth1>lgth2?lgth1:lgth2;
            13     str3[k+1]='\0';
            14     i=0;j=0;
            15     while(*(str1+i)!='\0')i++;i--;
            16     while(*(str2+j)!='\0')j++;j--;
            17     c=0;
            18     for(;i>=0 || j>=0;i--,j--,k--)
            19     {
            20         if(j<0)add2num='0';
            21         else add2num=*(str2+j);
            22         if(i<0)add1num='0';
            23         else add1num=*(str1+i);
            24         tmp=add1num-'0'+add2num-'0'+c;
            25         *(str3+k)=tmp%10+'0';
            26         c=tmp/10;
            27     }
            28     if(c!=0)
            29         *(str3+k)=c+'0';
            30     else
            31     {
            32         for(i=0;*(str3+i+1)!='\0';i++)
            33             *(str3+i)=*(str3+i+1);
            34         *(str3+i)='\0';
            35     }
            36 }
            37 
            38 int main()
            39 {
            40     int n,j;
            41     char str1[1003],str2[1003],Fibo[1003];
            42     while(scanf("%d",&n)!=EOF)
            43     {
            44         memset(str1,0,1003);
            45         memset(str2,0,1003);
            46         memset(Fibo,0,1003);
            47         strcpy(str2,"1");
            48         for(j=1;j<=n;j++)
            49         {
            50             memset(str1,0,1003);
            51             strcpy(str1,str2);
            52             memset(str2,0,1003);
            53             strcpy(str2,Fibo);
            54             addstr(str1,str2,Fibo);
            55         }
            56         printf("%s\n",Fibo);
            57     }
            58     return 0;
            59 }


            亚洲欧美日韩精品久久亚洲区 | 久久99精品久久久久久噜噜| 精品久久久久中文字幕日本| 94久久国产乱子伦精品免费| 中文字幕精品久久久久人妻| 久久精品国产精品亚洲毛片| 久久精品无码一区二区三区日韩| 久久久久久综合网天天| 亚洲国产成人久久综合一 | 国产巨作麻豆欧美亚洲综合久久 | 久久涩综合| 国产精品久久波多野结衣| 久久AⅤ人妻少妇嫩草影院| 女人高潮久久久叫人喷水| 九九99精品久久久久久| 97久久国产综合精品女不卡| 99精品久久久久久久婷婷| 久久妇女高潮几次MBA| 国产精品久久久久久久久鸭| 青青热久久国产久精品| 内射无码专区久久亚洲| 久久久国产精品亚洲一区| 三级三级久久三级久久| 精品久久久无码中文字幕| 99国产精品久久| 久久亚洲精品人成综合网| 青青草原综合久久大伊人| 国产一区二区精品久久凹凸| 久久99久久99小草精品免视看| 亚洲人成无码www久久久| 亚洲国产精久久久久久久| 精品久久久久久久| 97久久超碰国产精品旧版| 久久综合狠狠综合久久综合88| 久久国产免费直播| 久久影院综合精品| 久久大香香蕉国产| 久久99精品国产99久久6男男| 久久电影网一区| 久久青草国产精品一区| 曰曰摸天天摸人人看久久久|