• <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  評論-4  文章-0  trackbacks-0

            指定一個數組,比如整數或字符串, 長度為N, 將其循環右移K位.

            以下是我的解法: 只需要遍歷一次數組即可. 空間復雜度是o(1), 時間復雜度是o(N).
            不同于其他的解法: 1) 不需要求GCD(N,K) 2)不需要遍歷2遍數組(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) 評論(2)  編輯 收藏 引用 所屬分類: algorithmc/c++

            評論:
            # re: 數組 循環位移 或 循環移動 (左移 或 右移) K位(轉移自博客園) 2009-05-26 19:50 | ruory
            C語言真的挺難學,我肯定會掛科!
              回復  更多評論
              
            # re: 數組 循環位移 或 循環移動 (左移 或 右移) K位(轉移自博客園) 2009-10-16 00:14 | 減肥中的小朋友
            學這個會死人的,超難啊~~~  回復  更多評論
              
            久久亚洲精品成人av无码网站| 国产精品99久久久久久www| 亚洲国产精品综合久久网络 | 99久久超碰中文字幕伊人| 久久精品国产亚洲AV无码麻豆| 国产精品久久久久9999| 国产精品欧美久久久久无广告| 中文字幕久久亚洲一区| 精品国产乱码久久久久久郑州公司 | 久久99国产精品成人欧美| 久久乐国产精品亚洲综合| 久久精品亚洲AV久久久无码| 久久精品国产秦先生| 久久久久久伊人高潮影院| 国产精品无码久久综合网| 久久综合香蕉国产蜜臀AV| 色综合久久久久综合99| 国产V亚洲V天堂无码久久久| 久久久久亚洲AV综合波多野结衣| 欧美熟妇另类久久久久久不卡| 日韩久久无码免费毛片软件 | 日韩欧美亚洲综合久久 | 久久久久97国产精华液好用吗| 久久夜色精品国产网站| 久久只有这精品99| 狠狠人妻久久久久久综合蜜桃| 97久久超碰成人精品网站| 热99RE久久精品这里都是精品免费 | 久久久免费精品re6| 日日狠狠久久偷偷色综合96蜜桃| 91精品国产色综合久久| 成人久久免费网站| 日韩人妻无码一区二区三区久久99| 久久久久97国产精华液好用吗| 99久久精品无码一区二区毛片| 99久久er这里只有精品18| 久久久婷婷五月亚洲97号色| 久久无码人妻一区二区三区| 囯产极品美女高潮无套久久久 | 久久99精品国产99久久6| 青青草国产精品久久|