青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Jiang's C++ Space

創作,也是一種學習的過程。

   :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
最近做東西的時候出現這么一個問題,看起來很簡單的:
#define LARGE_SIZE 1024
#define ELEMENT_NUM 5
class CItem
{
public:
 TCHAR cID;
 BYTE data[LARGE_SIZE];
};

CItem data[ELEMENT_NUM];

INT reposition[ELEMENT_NUM] 
= {4,2,0,3,1};
要求,根據repositon的內容調整data的內容,如上,把原來下標4的元素調到0,把原來下標2的元素調到1。

寫個算法,復雜度為O(n),還要盡量節省空間,因為LARGE_SIZE可以很大,并且ELEMENT_NUM可能遠遠不止5個元素。

馬上能想到的方法就是:
    INT i;
    CItem 
*pToHandle = new CItem[ELEMENT_NUM];
    memcpy(pToHandle, data, 
sizeof(data));
    
for(i=0; i<ELEMENT_NUM; i++)
    {
        data[i] 
= pToHandle[reposition[i]];
    }
    delete[] pToHandle;
但這不太符合節省空間的原則,有可能在一個嵌入式平臺中,new操作就會失敗。

問題看起來是簡單,但卻耗費了我不少時間,才寫出這么一個算法,我直接貼上全部代碼:
#include "stdafx.h"
#include 
<Windows.h>

#define LARGE_SIZE 1024

class CItem
{
public:
    TCHAR cID;
    BYTE data[LARGE_SIZE];
};

#define ELEMENT_NUM 10

int _tmain(int argc, _TCHAR* argv[])
{
    
//Data to test
    CItem allData[ELEMENT_NUM];
    INT i;
    
for (i=0; i<ELEMENT_NUM; i++)
    {
        allData[i].cID 
= 'A' + i;
    }

    INT position[ELEMENT_NUM] 
= {5143697208};
    
//The result be    F  B  E  D  G  J  H  C  A  I

    
for (i=0; i<ELEMENT_NUM; i++)
    {
        CItem swapItem;
        
if (position[i]==i)
            
continue;
        swapItem 
= allData[i];
        
        INT iSeek 
= i;
        
do 
        {
            INT iToSeekNext 
= position[iSeek];
            allData[iSeek] 
= allData[iToSeekNext];
            position[iSeek] 
= iSeek;
            iSeek 
= iToSeekNext;
        } 
while (position[iSeek]!=i);

        allData[iSeek] 
= swapItem;
        position[iSeek] 
= iSeek;
    }

    
for (i=0; i<ELEMENT_NUM; i++)
    {
        _tprintf(TEXT(
"%c "), allData[i].cID);
    }
    _tprintf(TEXT(
"\n"));

    
return 0;
}
看起來寫得稍微有些亂,而且明顯用了兩層迭代,按道理說算法復雜度應該為O(n2)了,但再仔細分析代碼后發覺:需要調整位置的元素,只需要移動一次,而整個遍歷過程并不會出現重復遍歷的情況。因此其實際復雜度應該為O(n),已經是最高效了,看看還有沒別的辦法。
posted on 2010-11-27 18:58 Jiang Guogang 閱讀(483) 評論(0)  編輯 收藏 引用 所屬分類: Knowledge
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            宅男在线国产精品| 午夜日韩电影| 欧美激情按摩| 99re6这里只有精品视频在线观看| 老司机免费视频久久| 久久精品道一区二区三区| 伊人成人在线视频| 欧美激情一区二区三区在线视频| 欧美成人免费播放| 亚洲一级二级| 欧美一区二区三区视频在线观看| 国产一区二区三区免费在线观看| 久久夜色精品国产欧美乱| 欧美成人一区二区三区| 一本大道久久a久久综合婷婷| 在线综合亚洲| 国产在线不卡视频| 亚洲黄网站在线观看| 欧美美女喷水视频| 久久国产加勒比精品无码| 久久久视频精品| 亚洲精品视频在线看| 亚洲欧美日韩精品久久久| 在线视频国产日韩| 一本综合精品| 伊人久久亚洲影院| 制服丝袜激情欧洲亚洲| 国内激情久久| 日韩天堂在线视频| 在线观看成人一级片| 日韩午夜电影| 在线免费日韩片| 亚洲男女自偷自拍| 亚洲精品自在久久| 欧美在线一级va免费观看| 亚洲精品视频在线播放| 篠田优中文在线播放第一区| 99精品欧美一区二区三区| 欧美在线播放高清精品| 亚洲视频网在线直播| 狂野欧美一区| 久久精品亚洲精品| 欧美色图一区二区三区| 免费欧美视频| 国产色爱av资源综合区| 一本色道久久综合精品竹菊| 亚洲黄色性网站| 欧美亚洲综合久久| 午夜日韩av| 欧美日韩国产限制| 欧美激情一区在线| 一区二区视频免费在线观看| 亚洲一区国产视频| 亚洲欧美日韩中文视频| 欧美日韩1区| 亚洲精品国久久99热| 亚洲精品久久久久久久久久久久久| 先锋资源久久| 欧美一级艳片视频免费观看| 欧美日韩中文字幕在线| 亚洲精品国产品国语在线app| 亚洲福利专区| 久久久久女教师免费一区| 久久高清国产| 国产色综合久久| 亚洲欧美综合v| 欧美一区高清| 国产中文一区二区| 欧美在线影院| 久久人人看视频| 在线成人www免费观看视频| 久久成人免费网| 鲁大师影院一区二区三区| 在线观看三级视频欧美| 老司机久久99久久精品播放免费 | 国产精品一区三区| 亚洲综合色自拍一区| 欧美一区二区三区免费观看视频| 国产精品视频内| 久久岛国电影| 欧美国内亚洲| 中文有码久久| 国产亚洲aⅴaaaaaa毛片| 久久精品国产免费看久久精品| 久久在线视频| 亚洲欧洲另类国产综合| 欧美日韩国产限制| 亚洲综合成人婷婷小说| 久久中文字幕一区二区三区| 亚洲夫妻自拍| 欧美日韩亚洲视频一区| 亚洲欧美美女| 欧美ed2k| 亚洲在线成人| 在线免费高清一区二区三区| 欧美精品手机在线| 亚洲欧美日韩系列| 欧美国产视频日韩| 亚洲欧美日韩精品久久奇米色影视| 国产日韩欧美日韩大片| 久久女同互慰一区二区三区| 亚洲欧洲综合另类在线| 欧美一区二区视频网站| 亚洲人成7777| 国产乱码精品一区二区三区五月婷 | 亚洲免费视频在线观看| 麻豆精品一区二区综合av| 这里只有精品视频| 黄色一区三区| 欧美日韩视频专区在线播放 | 99视频一区二区| 久久在线观看视频| 亚洲主播在线播放| 亚洲激情电影中文字幕| 国产女主播一区| 欧美日韩精选| 美女啪啪无遮挡免费久久网站| 夜夜爽www精品| 亚洲二区视频| 久久综合九色九九| 亚洲欧美日韩国产中文| 亚洲理伦在线| 亚洲成色999久久网站| 国产精品日韩精品欧美精品| 欧美激情一区二区三级高清视频 | 久久精品国产一区二区三区| 一区二区三区福利| 91久久午夜| 久久综合久久久| 久久精品一区蜜桃臀影院| 亚洲欧美韩国| 亚洲一区二区高清视频| 亚洲日本欧美在线| 亚洲国产另类 国产精品国产免费| 国产亚洲欧美色| 国产精品亚洲综合久久| 欧美视频三区在线播放| 欧美日韩福利视频| 欧美日韩国产精品一卡| 欧美精品在线观看一区二区| 免费不卡在线视频| 欧美大片在线观看| 久热成人在线视频| 久久久久久久综合色一本| 久久精品夜色噜噜亚洲a∨| 欧美一级大片在线观看| 欧美一区二区三区四区夜夜大片 | 一区二区三区精品国产| 亚洲精品中文字| 亚洲欧洲一区| 亚洲日本国产| 一二三区精品| 亚洲欧美怡红院| 欧美在线免费观看亚洲| 久久精品欧洲| 欧美电影免费观看大全| 欧美精品首页| 国产精品盗摄一区二区三区| 国产精品久久久999| 国产日韩一区欧美| 一区二区亚洲精品国产| 亚洲国产日韩一区二区| 夜夜嗨av一区二区三区中文字幕| 在线综合+亚洲+欧美中文字幕| 一区二区免费在线播放| 午夜精品久久久久久久蜜桃app | 久久久精品五月天| 免费看黄裸体一级大秀欧美| 欧美激情一区二区三区在线视频观看| 欧美国产大片| 日韩性生活视频| 亚洲欧美视频在线| 久久久中精品2020中文| 欧美久久久久久| 国产欧美一区二区三区国产幕精品| 国产综合在线看| 亚洲黄色尤物视频| 亚洲一区二区三区免费视频| 久久久久久久性| 欧美激情免费观看| 亚洲自拍偷拍网址| 欧美xxx在线观看| 国产精品电影在线观看| 在线观看欧美视频| 亚洲欧美bt| 欧美电影在线播放| 在线视频日韩| 久久婷婷国产综合国色天香| 欧美三级资源在线| 亚洲国产成人av好男人在线观看| 亚洲私人影院| 欧美激情自拍| 欧美在线视频播放| 欧美日韩在线观看一区二区三区| 国产尤物精品| 午夜日本精品| 99av国产精品欲麻豆| 猛干欧美女孩| 国产亚洲欧美日韩精品| 亚洲一二三四区|