• <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 - 43,  comments - 9,  trackbacks - 0
            http://acm.hdu.edu.cn/showproblem.php?pid=1005
            A number sequence is defined as follows:
            f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7.
            Given A, B, and n, you are to calculate the value of f(n).
            1 <= A, B <= 1000, 1 <= n <= 100,000,000

            解:
            f(n) = (A * f(n - 1) + B * f(n - 2)) %7
                  = (A * f(n - 1) %7 + B * f(n - 2) %7) %7
            所以對于給定的A和B,可以先打表,找出數(shù)列的循環(huán)部分. 鴿巢原理知,狀態(tài)總數(shù)不會超過7*7
            注意循環(huán)節(jié)不一定從f(3)開始...

             1#include <iostream>
             2using namespace std;
             3
             4int a,b,n,x,y,l,h,m[7][7],q[300];
             5int main(){
             6    while(scanf("%d%d%d",&a,&b,&n)!=EOF && (a||b||n)){
             7        memset(m, 0sizeof(m));
             8        q[1= q[2= 1;
             9        x = y = 1; l=3;
            10        while(m[x][y]==0)//該狀態(tài)還未經(jīng)歷過,則擴展
            11            q[l] = (a*x+b*y)%7;
            12            m[x][y] = l;
            13            y = x;
            14            x = q[l++];
            15        }

            16        //此時,q[1h-1]為前面的非循環(huán)部分
            17         //q[hl-1]為循環(huán)節(jié)
            18        h = m[x][y]; //循環(huán)節(jié)的起始位置
            19        if(n<h) printf("%d\n",q[n]);
            20        else printf("%d\n",q[((n-h)%(l-h))+h]);
            21    }

            22    return 0;
            23}

            posted on 2009-04-25 11:55 wolf5x 閱讀(910) 評論(0)  編輯 收藏 引用 所屬分類: acm_icpc
            <2009年7月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            "Do not spend all your time on training or studying - this way you will probably become very exhausted and unwilling to compete more. Whatever you do - have fun. Once you find programming is no fun anymore – drop it. Play soccer, find a girlfriend, study something not related to programming, just live a life - programming contests are only programming contests, and nothing more. Don't let them become your life - for your life is much more interesting and colorful." -- Petr

            留言簿(3)

            隨筆分類(59)

            隨筆檔案(43)

            cows

            搜索

            •  

            最新評論

            評論排行榜

            久久99这里只有精品国产| 久久亚洲国产精品成人AV秋霞| 国产精品视频久久久| 久久亚洲欧美日本精品| 欧美激情精品久久久久久| 中文字幕无码免费久久| 97精品国产97久久久久久免费 | 亚洲综合精品香蕉久久网97| 色综合合久久天天综合绕视看 | 一本色道久久88综合日韩精品| 久久久久人妻一区精品性色av| 久久e热在这里只有国产中文精品99| 亚洲国产日韩欧美久久| 91精品国产综合久久香蕉| 久久亚洲精品国产精品| 亚洲午夜久久久| 国产精品内射久久久久欢欢| 久久ZYZ资源站无码中文动漫| 国产99久久久国产精品小说| 国产成人久久久精品二区三区| 97久久天天综合色天天综合色hd| 中文成人久久久久影院免费观看 | 国产精品伊人久久伊人电影 | 久久精品中文字幕有码| 国产亚洲欧美精品久久久| 久久综合给合综合久久| 97久久精品无码一区二区天美| 国产免费久久久久久无码| 青青青国产成人久久111网站| 久久99精品久久久久久久久久| 欧美一区二区三区久久综合| 亚洲午夜久久久久妓女影院| 久久人人爽人人爽人人片av麻烦| 亚洲国产精品成人久久蜜臀| 亚洲国产小视频精品久久久三级 | 国内精品久久久久久久coent| 久久精品视频网| 久久精品成人欧美大片| 思思久久99热免费精品6| 久久久黄色大片| 久久天堂AV综合合色蜜桃网|