• <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>
            隨筆-72  評(píng)論-126  文章-0  trackbacks-0
            矩陣運(yùn)算。。很早的時(shí)候就下了一個(gè)課件,不過(guò)一直沒(méi)有看,因?yàn)椴恢朗裁吹胤娇梢杂茫](méi)看當(dāng)然不知道了)
            前幾天做了FOJ的月賽,有一道遞推的題
            賽后問(wèn)了紀(jì)哥知道是矩陣的題目
            補(bǔ)習(xí)了一下,看了那個(gè)資料

            發(fā)現(xiàn)原來(lái)這么簡(jiǎn)單,推推題原來(lái)都可以這樣做。。
            在HDOJ練習(xí)了幾道題目
            http://acm.hdu.edu.cn/showproblem.php?pid=1575
            這道是赤裸裸的矩陣二分
            http://acm.hdu.edu.cn/showproblem.php?pid=2256
            這道要巧妙的轉(zhuǎn)化后推公式
            再去解決FOJ那題。
            http://acm.fzu.edu.cn/problem.php?pid=1683
            Sn的公式很快就推出來(lái)了,用矩陣二分竟然超時(shí)。。。
            后來(lái)經(jīng)指點(diǎn)是取模次數(shù)太多了,經(jīng)過(guò)多次修改,終于過(guò)了。。

            又一想,當(dāng)年菜鳥(niǎo)杯一道推推題目知道公式但是。怎么也寫不出
            http://acm.hdu.edu.cn/showproblem.php?pid=2604
            現(xiàn)在知道矩陣后回去秒殺了,呵呵,開(kāi)心。。。
            http://acm.hdu.edu.cn/showproblem.php?pid=1757
            這道也是赤裸裸的矩陣
            http://acm.hdu.edu.cn/showproblem.php?pid=1588
            這題目比較惡心,不經(jīng)init矩陣要自己推
            連右邊的數(shù)字都要自己推。。。推了一個(gè)晚上。。。結(jié)果效率還不是最高的,15MS
            http://acm.hdu.edu.cn/showproblem.php?pid=2276
            這道比賽時(shí)候看不出是矩陣。。。后來(lái)知道了很好做,因?yàn)樯舷孪嗖钜恍校苯觧^2的算法可以代替n^3,爽阿
            http://acm.fzu.edu.cn/problem.php?pid=1692
            還有這道,也是n^2的代替n^3防止超時(shí)
            //用n^2代替n^3的方法如下:
            //因?yàn)槭翘厥饩仃嚕撼跏季仃嚿舷轮幌嗖钜涣?br>//所以可以計(jì)算第一行然后通過(guò)移位來(lái)得到全部矩陣

            Matr Mul(Matr a,Matr b)
            {
                
            int i,j,k;
                Matr c;
                
            for(j=0;j<n;j++)
                {
                    c.num[
            0][j] = 0;
                    
            for(k=0;k<n;k++)
                        c.num[
            0][j] += a.num[0][k]*b.num[k][j];
                    c.num[
            0][j] &= 1;
                }
                
            for(i=1;i<n;i++)
                {
                    c.num[i][
            0= c.num[i-1][n-1];
                    
            for(j=1;j<n;j++)
                        c.num[i][j] 
            = c.num[i-1][j-1];
                }
                
            return c;
            }


            http://acm.hdu.edu.cn/showproblem.php?pid=2294
            這道baidu杯過(guò)的最少的竟然也是用到矩陣,賽后看結(jié)題報(bào)告才知道,神奇

            分享一下我的矩陣模板吧
            struct Mat{
                
            int matrix[4][4];
            }init,unit;
            int mod;
            Mat Mul(Mat a,Mat b)//據(jù)說(shuō)傳結(jié)構(gòu)體比傳數(shù)組快
            {
                
            int i,j,k;
                Mat c;
                
            for(i=0;i<4;i++)
                    
            for(j=0;j<4;j++)
                    {
                        c.matrix[i][j] 
            = 0;
                        
            for(k=0;k<4;k++)
                            c.matrix[i][j] 
            += a.matrix[i][k]*b.matrix[k][j];
                        
            if(c.matrix[i][j]>=mod)
                            c.matrix[i][j]
            %=mod;
                    }
                
            return c;
            }
            Mat cal(
            int l)//l代表冪
            {
                Mat p,q;
                p 
            = unit;
                q 
            = init;
                
            while(l!=1)
                {
                    
            if(l&1)
                    {
                        l
            --;
                        p 
            = Mul(p,q);
                    }
                    
            else
                    {
                        l
            >>=1;
                        q 
            = Mul(q,q);
                    }
                }
                p 
            = Mul(p,q);
                
            return p;
            }

                
            for(i=0;i<4;i++)
                    
            for(j=0;j<4;j++)
                        unit.matrix[i][j] 
            = (i==j);
            posted on 2009-03-03 14:17 shǎ崽 閱讀(2298) 評(píng)論(8)  編輯 收藏 引用

            評(píng)論:
            # re: 神奇的matrix運(yùn)算 2009-03-20 20:46 | future
            http://acm.fzu.edu.cn/problem.php?pid=1683
            Sn的公式很快就推出來(lái)了,。。。。”
            我這題用矩陣冪暴力做就TLE掉了,
            請(qǐng)問(wèn)你sn公式是怎么推的!能否告知一下!謝謝~~  回復(fù)  更多評(píng)論
              
            # re: 神奇的matrix運(yùn)算 2009-03-23 14:00 | shǎ崽
            @future


            A = [1 1 0 0]
            [0 3 2 7]
            [0 1 0 0]
            [0 0 1 0]

            B = [Sn]
            [Fn-1]
            [Fn-2]
            [Fn-3]  回復(fù)  更多評(píng)論
              
            # re: 神奇的matrix運(yùn)算 2009-04-12 09:19 | ouye
            大牛
            http://acm.hdu.edu.cn/showproblem.php?pid=2256
            這道要巧妙的轉(zhuǎn)化后推公式

            后推公式是怎么推得?能否告知,thanks

              回復(fù)  更多評(píng)論
              
            # re: 神奇的matrix運(yùn)算 2009-04-12 11:51 | matrix
            http://acm.hdu.edu.cn/showproblem.php?pid=2276
            這道比賽時(shí)候看不出是矩陣。。。后來(lái)知道了很好做,因?yàn)樯舷孪嗖钜恍校苯觧^2的算法可以代替n^3

            大牛, 可以具體解釋下嗎? 謝  回復(fù)  更多評(píng)論
              
            # re: 神奇的matrix運(yùn)算 2009-04-13 00:09 | shǎ崽
            @matrix


            因?yàn)樯舷轮幌嗖钜晃?
            所以可以用





            只算出第一行,然后接下來(lái)的根據(jù)移位得到

            。。。
            算了,這里格式不好,我貼到上邊去

              回復(fù)  更多評(píng)論
              
            # re: 神奇的matrix運(yùn)算 2009-04-13 00:12 | shǎ崽
            @ouye


            num[1] = 10;
            num[2] = 98
            num[i] = num[i-1]*10 - num[i-2];

            然后num[i] - 1就是所求的答案  回復(fù)  更多評(píng)論
              
            # re: 神奇的matrix運(yùn)算 2009-05-03 14:38 | phoenix
            能否提供下關(guān)于矩陣運(yùn)算的課件給我,謝了~  回復(fù)  更多評(píng)論
              
            # re: 神奇的matrix運(yùn)算 2009-05-08 21:39 | Wpl
            牛.......  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            老色鬼久久亚洲AV综合| av国内精品久久久久影院| 久久精品亚洲乱码伦伦中文| 青青国产成人久久91网| 久久一本综合| 国产精品久久毛片完整版| 色婷婷久久综合中文久久一本| 久久久噜噜噜久久中文字幕色伊伊| 国内精品久久久久久久97牛牛| 热综合一本伊人久久精品| 色综合久久久久无码专区| 久久久久99精品成人片三人毛片| 中文字幕乱码久久午夜| 久久天天躁狠狠躁夜夜av浪潮| 久久人人爽人人爽人人片av高请| 国产成人精品久久综合| 久久永久免费人妻精品下载| 蜜桃麻豆www久久国产精品| 久久99精品国产自在现线小黄鸭| 日韩欧美亚洲国产精品字幕久久久| 久久精品麻豆日日躁夜夜躁| 一本一本久久a久久精品综合麻豆| 99久久精品国产毛片| 99久久精品费精品国产一区二区| 久久亚洲精品成人无码网站| 国产精品亚洲综合专区片高清久久久| 久久亚洲欧美国产精品| 欧美久久久久久| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 国产aⅴ激情无码久久| 精品久久久久久无码中文野结衣| 久久99亚洲网美利坚合众国| 亚洲国产精品久久电影欧美| 久久影院亚洲一区| 久久亚洲电影| 久久久精品波多野结衣| 久久久久无码国产精品不卡| 久久免费视频6| 久久精品亚洲AV久久久无码| 99精品国产99久久久久久97| 亚洲国产精品无码久久|