• <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>
            隨筆-6  評(píng)論-4  文章-0  trackbacks-0

            指定一個(gè)數(shù)組,比如整數(shù)或字符串, 長(zhǎng)度為N, 將其循環(huán)右移K位.

            以下是我的解法: 只需要遍歷一次數(shù)組即可. 空間復(fù)雜度是o(1), 時(shí)間復(fù)雜度是o(N).
            不同于其他的解法: 1) 不需要求GCD(N,K) 2)不需要遍歷2遍數(shù)組(STL源碼中的reverse算法)


            void Output(int *pBuffer, int nCount)
            {
                if(!pBuffer || !nCount) return;

                for (size_t i = 0; i < nCount; i++)
                {
                    printf(" %d ", pBuffer[i]);
                }

                printf("\n");

            }

            void ShiftN(int *pBuffer, int nCount, int nShiftN)
            {
                if(!pBuffer || !nCount || !nShiftN) return;

                nShiftN %= nCount;

                int nIndex = 0;
                int nStart  = nIndex;

                int nTemp  = pBuffer[nIndex];

                for (size_t i = 0; i < nCount; i++)
                {
                    nIndex = (nIndex + nShiftN) % nCount;

                    pBuffer[nIndex] ^= nTemp ^=
                    pBuffer[nIndex] ^= nTemp ;

                    if(nIndex == nStart)
                    {
                        nStart ++;
                        nIndex = nStart;
                        nTemp = pBuffer[nIndex];
                    }
                }
            }

            int main(int argc, char* argv[])
            {
                int buffer[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12};

                int nCount = sizeof(buffer) / sizeof(int);

                Output(buffer, nCount);

                ShiftN(buffer, nCount, 8);

                Output(buffer, nCount);
               
                return 0;
            }

            posted on 2008-12-30 19:50 vcfly 閱讀(3573) 評(píng)論(2)  編輯 收藏 引用 所屬分類: algorithmc/c++

            評(píng)論:
            # re: 數(shù)組 循環(huán)位移 或 循環(huán)移動(dòng) (左移 或 右移) K位(轉(zhuǎn)移自博客園) 2009-05-26 19:50 | ruory
            C語(yǔ)言真的挺難學(xué),我肯定會(huì)掛科!
              回復(fù)  更多評(píng)論
              
            # re: 數(shù)組 循環(huán)位移 或 循環(huán)移動(dòng) (左移 或 右移) K位(轉(zhuǎn)移自博客園) 2009-10-16 00:14 | 減肥中的小朋友
            學(xué)這個(gè)會(huì)死人的,超難啊~~~  回復(fù)  更多評(píng)論
              

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


            91精品国产高清久久久久久91 | 久久精品国产亚洲Aⅴ蜜臀色欲| 97热久久免费频精品99| 精品久久8x国产免费观看| 嫩草影院久久国产精品| 亚洲乱码日产精品a级毛片久久 | 一本久久a久久精品综合香蕉| 伊人久久精品影院| 国产精品久久久久无码av| 日日狠狠久久偷偷色综合96蜜桃| 久久热这里只有精品在线观看| 国内精品久久久久影院优| 免费精品久久久久久中文字幕| 日日噜噜夜夜狠狠久久丁香五月| 亚洲成人精品久久| 色偷偷久久一区二区三区| 国产呻吟久久久久久久92| 久久午夜无码鲁丝片| 天天做夜夜做久久做狠狠| 青青草国产精品久久久久| 囯产精品久久久久久久久蜜桃 | 久久婷婷五月综合97色直播| 久久综合狠狠综合久久综合88 | 99久久这里只有精品| 久久这里有精品| 久久久久亚洲AV无码去区首| 国内精品伊人久久久久| 亚洲人成伊人成综合网久久久| 精品久久久久一区二区三区 | 日韩久久无码免费毛片软件| 久久青草国产手机看片福利盒子| 亚洲av成人无码久久精品 | 高清免费久久午夜精品| 嫩草伊人久久精品少妇AV| 久久天天躁狠狠躁夜夜avapp| 久久婷婷五月综合成人D啪| 韩国三级中文字幕hd久久精品| 久久久亚洲欧洲日产国码二区 | 国产日韩久久免费影院| 狠狠人妻久久久久久综合蜜桃| 久久这里只精品国产99热|