• <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>

            hdu 3584 Cube 三維樹狀數(shù)組

               這個題意思是翻轉(zhuǎn)一個01立方體。翻轉(zhuǎn)多次后再查詢某個點的值。
               還是利用上一篇文章的思想,把翻轉(zhuǎn)操作轉(zhuǎn)換為單點更新操作。把查詢操作轉(zhuǎn)換為利用樹狀數(shù)組查詢和的方式。
            這樣每次操作的復(fù)雜度都是logN的3次。而直接翻轉(zhuǎn)立方體的復(fù)雜度是N的3次。
               這個題最麻煩的地方是空間想象能力。因為要翻轉(zhuǎn)8個點才能完成一次立方體翻轉(zhuǎn)。比如,翻轉(zhuǎn)(x,y,z)相當(dāng)于
            以該點作為左上角做一個無限立方體,把該立方體翻轉(zhuǎn)。這樣就會翻轉(zhuǎn)多余的部分,那么需要把多翻轉(zhuǎn)的部分翻轉(zhuǎn)
            回來。最后的思考結(jié)果發(fā)現(xiàn),只要對每個頂點翻轉(zhuǎn)一次即可。至于為什么這樣,自己去計算重復(fù)翻轉(zhuǎn)的部分就會明白
            了。剛好確實是把每個點翻轉(zhuǎn)了一次。
               
               代碼如下:
            #include <stdio.h>
            #include <string.h>
            #include <algorithm>
            using namespace std;

            const int MAX_N = 110;
            int nSum[MAX_N + 10][MAX_N + 10][MAX_N + 10];
            int nN, nM;

            int LowBit(int nPos)
            {
                return nPos & (-nPos);
            }

            void Add(int nX, int nY, int nZ)
            {
                for (int i = nX; i <= nN; i += LowBit(i))
                {
                    for (int j = nY; j <= nN; j += LowBit(j))
                    {
                        for (int k = nZ; k <= nN; k += LowBit(k))
                        {
                            nSum[i][j][k]++;
                        }
                    }
                }
            }

            int Query(int nX, int nY, int nZ)
            {
                int nAns = 0;
                
                for (int i = nX; i > 0; i -= LowBit(i))
                {
                    for (int j = nY; j > 0; j -= LowBit(j))
                    {
                        for (int k = nZ; k > 0; k -= LowBit(k))
                        {
                            nAns += nSum[i][j][k];
                        }
                    }
                }
                return nAns;
            }

            int main()
            {
                int nCmd;
                int nX, nY, nZ;
                int nX1, nY1, nZ1;
                int nX2, nY2, nZ2;
                
                while (scanf("%d%d", &nN, &nM) == 2)
                {
                    memset(nSum, 0, sizeof(nSum));
                    while (nM--)
                    {
                        scanf("%d", &nCmd);
                        if (nCmd == 0)
                        {
                            scanf("%d%d%d", &nX, &nY, &nZ);
                            printf("%d\n", Query(nX, nY, nZ) % 2);
                        }
                        else
                        {
                            scanf("%d%d%d%d%d%d", &nX1, &nY1, &nZ1, &nX2, &nY2, &nZ2);
                            if (nX1 > nX2)swap(nX1, nX2);
                            if (nY1 > nY2)swap(nY1, nY2);
                            if (nZ1 > nZ2)swap(nZ1, nZ2);
                            Add(nX1, nY1, nZ1);
                            
                            Add(nX2 + 1, nY1, nZ1);
                            Add(nX1, nY2 + 1, nZ1);
                            Add(nX1, nY1, nZ2 + 1);
                            
                            Add(nX1, nY2 + 1, nZ2 + 1);
                            Add(nX2 + 1, nY1, nZ2 + 1);
                            Add(nX2 + 1, nY2 + 1, nZ1);
                            
                            Add(nX2 + 1, nY2 + 1, nZ2 + 1);
                        }
                    }
                }
                
                return 0;
            }

            posted on 2012-09-10 15:43 yx 閱讀(1577) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)

            <2012年9月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導(dǎo)航

            統(tǒng)計

            公告

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            me

            好友

            同學(xué)

            網(wǎng)友

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            狠狠色丁香久久综合五月| 91精品观看91久久久久久| 99久久精品国产一区二区| 人妻无码中文久久久久专区| 成人综合伊人五月婷久久| 久久五月精品中文字幕| 久久99国产综合精品女同| 欧美国产精品久久高清| 久久狠狠色狠狠色综合| 久久久久亚洲AV片无码下载蜜桃| 国产精品久久永久免费| 亚洲午夜无码久久久久| 日本高清无卡码一区二区久久| AV无码久久久久不卡蜜桃| 国产激情久久久久久熟女老人| 久久国产精品波多野结衣AV| 精品久久久久久中文字幕人妻最新| 久久精品无码一区二区三区免费 | 手机看片久久高清国产日韩| 无码国产69精品久久久久网站| 国产成人精品久久综合| 99久久久国产精品免费无卡顿| 久久精品国产99国产精品导航| 久久精品无码一区二区日韩AV| 久久美女人爽女人爽| 国产精品久久久亚洲| 久久免费的精品国产V∧| 久久久久久久久久久精品尤物| 中文字幕精品久久| 亚洲精品NV久久久久久久久久| 久久久久国产一区二区| 久久婷婷色综合一区二区| 久久久噜噜噜久久| 色综合久久中文字幕综合网| 久久久久久国产精品免费免费| 久久AAAA片一区二区| 无码任你躁久久久久久久| 久久天天躁狠狠躁夜夜躁2014| 免费精品久久天干天干| 性色欲网站人妻丰满中文久久不卡| 久久亚洲精品无码AV红樱桃|