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

Jiang's C++ Space

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

   :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
數組是最最常用的數據結構之一,我們現在往數組中加入元素,當數組被加滿時,我們希望最早加入數組的元素就被沖掉,像一個隊列那樣,那應該如何實現呢?我寫了個類模板,非常簡單,初步測試下來還沒發現什么問題。
#pragma once

#define DEFAULT_ARRAY_SIZE 20
#define MINIMUM_ARRAY_SIZE 5

template 
<class T>
class CRollArray
{
public:
    CRollArray(
int iArraySize = DEFAULT_ARRAY_SIZE);
    
~CRollArray();
    T
& operator[] (int iIndex);
    
void Add(T element);
    
int GetSize();
    
void Reset();
private:
    T
* m_pData;
    
int m_iBegin;
    
int m_iEnd;
    
int m_iArrSize;
};

template 
<class T>
CRollArray
<T>::CRollArray(int iArraySize)
{
    
if (iArraySize<MINIMUM_ARRAY_SIZE)
        iArraySize
=MINIMUM_ARRAY_SIZE;

    m_pData 
= new T[iArraySize];
    m_iBegin 
= -1;
    m_iEnd 
= -1;
    m_iArrSize 
= iArraySize;
}

template 
<class T>
CRollArray
<T>::~CRollArray(void)
{
    
if(m_pData!=NULL)
        delete[] m_pData;
}

template 
<class T>
T
& CRollArray<T>::operator[] (int iIndex)
{
    
if (m_iBegin+iIndex<m_iArrSize)
        
return m_pData[m_iBegin+iIndex];
    
else
        
return m_pData[m_iBegin+iIndex-m_iArrSize];
}

template 
<class T>
void CRollArray<T>::Add(T element)
{
    
if(m_iEnd==m_iBegin-1)
    {
        
// xxxxEB
        if(m_iBegin==m_iArrSize-1)
        {
            m_iEnd 
= m_iBegin;
            m_iBegin 
= 0;
        }
        
// xxxEBx
        else
        {
            
++m_iEnd;
            
++m_iBegin;
        }
    }
    
else
    {
        
// Null array.
        if(m_iBegin==-1 && m_iEnd==-1)
        {
            m_iBegin 
= 0;
            m_iEnd 
= 0;
        }
        
else
        {
            
// BxxxxE
            if(m_iBegin==0 && m_iEnd==m_iArrSize-1)
            {
                
++m_iBegin;
                m_iEnd 
= 0;
            }
            
// BxxExx
            else
            {
                
++m_iEnd;
            }
        }
    }

    m_pData[m_iEnd] 
= element;
}

template 
<class T>
int CRollArray<T>::GetSize()
{
    
if (m_iEnd==m_iBegin-1 || (m_iBegin==0 && m_iEnd==m_iArrSize-1))
        
return m_iArrSize;

    
if(m_iBegin==-1 && m_iEnd==-1)
        
return 0;

    
return m_iEnd-m_iBegin+1;
}

template 
<class T>
void CRollArray<T>::Reset()
{
    m_iBegin 
= -1;
    m_iEnd 
= -1;
}
這是測試代碼:
#include "RollArray.h"

int _tmain(int argc, _TCHAR* argv[])
{
    CRollArray
<int> arrTest(10);
    printf(
"size: %d\n", arrTest.GetSize());
    arrTest.Add(
1);
    printf(
"size: %d\n", arrTest.GetSize());
    printf(
"idx0: %d\n", arrTest[0]);
    arrTest.Reset();
    printf(
"size: %d\n", arrTest.GetSize());
    arrTest.Add(
81);
    arrTest.Add(
4);
    arrTest.Add(
52);
    arrTest.Add(
123);
    arrTest.Add(
78);
    arrTest.Add(
987);
    arrTest.Add(
111);
    printf(
"size: %d\n", arrTest.GetSize());
    
int i;
    
for(i=0; i<arrTest.GetSize(); i++)
        printf(
"%d ", arrTest[i]);
    printf(
"\n");

    arrTest.Add(
321);
    arrTest.Add(
3);
    arrTest.Add(
2);
    arrTest.Add(
7);
    arrTest.Add(
54);
    arrTest.Add(
276);

    printf(
"size: %d\n", arrTest.GetSize());
    
for(i=0; i<arrTest.GetSize(); i++)
        printf(
"%d ", arrTest[i]);
    printf(
"\n");

    arrTest.Add(
94);
    arrTest.Add(
53);
    arrTest.Add(
40);
    arrTest.Add(
70);
    arrTest.Add(
102);
    arrTest.Add(
138);
    arrTest.Add(
461);
    arrTest.Add(
110);

    printf(
"size: %d\n", arrTest.GetSize());
    
for(i=0; i<arrTest.GetSize(); i++)
        printf(
"%d ", arrTest[i]);
    printf(
"\n");

    
return 0;
}
代碼執行結果如下:
size: 0
size: 1
idx0: 1
size: 0
size: 7
81 4 52 123 78 987 111
size: 10
123 78 987 111 321 3 2 7 54 276
size: 10
54 276 94 53 40 70 102 138 461 110
posted on 2010-06-18 13:10 Jiang Guogang 閱讀(438) 評論(1)  編輯 收藏 引用 所屬分類: Knowledge

評論

# re: 一個"滾動數組"類模板 2010-06-18 13:46 Matthew
哈哈,
重寫運算符,
我都沒有想到
我看到需求,第一個反應就是建立映射關系,
把相對應的index映射,浪費了內存,而且很不好用
  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美1区免费| 欧美—级高清免费播放| 国产精品你懂得| 午夜一区二区三视频在线观看 | 中文亚洲欧美| 99视频在线观看一区三区| 欧美日韩视频在线一区二区 | 亚洲欧洲日产国产综合网| 老**午夜毛片一区二区三区| 亚洲精品视频在线观看免费| 亚洲理伦在线| 国产手机视频一区二区| 蜜臀久久99精品久久久久久9| 蜜桃av一区二区在线观看| 99热在这里有精品免费| 亚洲一级黄色| 永久免费视频成人| 99人久久精品视频最新地址| 国产日韩精品一区| 亚洲激情视频在线| 国产欧美日韩不卡| 亚洲国产天堂久久综合| 国产精品久久久久免费a∨| 久久影视精品| 欧美网站在线观看| 欧美成人精品不卡视频在线观看| 欧美日韩另类一区| 久久全国免费视频| 欧美午夜不卡在线观看免费 | 一本色道久久综合狠狠躁的推荐| 国产精品高潮呻吟久久av无限| 久久免费偷拍视频| 欧美午夜电影网| 欧美激情一二区| 国产色爱av资源综合区| 最新日韩av| 在线观看91久久久久久| 亚洲免费视频一区二区| 日韩一区二区免费看| 久久成人这里只有精品| 亚洲一区三区在线观看| 美女精品视频一区| 久久久一二三| 国产精品无码永久免费888| 亚洲国产影院| 亚洲国产精品成人| 亚洲欧美视频一区| 亚洲女性裸体视频| 欧美日韩精品一区二区| 亚洲人成网站精品片在线观看 | 亚洲免费观看视频| 久久午夜国产精品| 久久久久久九九九九| 国产精品久久一区二区三区| 亚洲人线精品午夜| 亚洲精品三级| 欧美国产日韩视频| 亚洲国产成人av在线| 亚洲第一页中文字幕| 久久99伊人| 久久久久久久久久久成人| 国产麻豆一精品一av一免费| 一本到12不卡视频在线dvd| 一区二区三区|亚洲午夜| 欧美电影在线| 亚洲精品在线视频观看| 一区二区激情小说| 国产精品99一区| 亚洲综合电影一区二区三区| 亚洲欧美日韩精品在线| 国产乱码精品一区二区三区五月婷| 亚洲素人在线| 久久九九免费视频| 一区二区在线不卡| 另类尿喷潮videofree| 亚洲黄页视频免费观看| 亚洲视频播放| 国产精品激情av在线播放| 亚洲尤物在线视频观看| 久久激情久久| 亚洲第一区色| 欧美日韩一区在线观看| 在线视频精品一区| 久久久久综合网| 亚洲国产日韩美| 欧美色欧美亚洲高清在线视频| 亚洲一级免费视频| 久久天天躁夜夜躁狠狠躁2022| 亚洲大胆人体视频| 欧美日韩亚洲三区| 欧美一区二区三区视频在线| 欧美第一黄色网| 亚洲一区二区精品在线观看| 国产毛片精品视频| 欧美 亚欧 日韩视频在线| 一本一本a久久| 久久精品国产一区二区三区免费看| 亚洲国产精品视频一区| 国产精品久久久亚洲一区| 久久激情视频久久| 99在线精品观看| 久久久久久有精品国产| 一区二区电影免费在线观看| 国产在线视频不卡二| 欧美激情自拍| 久久av在线看| 中文av一区二区| 欧美黄色大片网站| 欧美中文字幕久久| 夜夜夜久久久| 在线观看欧美日本| 国产毛片一区二区| 欧美日韩在线播放| 久久久99国产精品免费| 亚洲另类自拍| 欧美大片免费观看| 久久精品网址| 午夜天堂精品久久久久| 亚洲精选大片| 亚洲丰满在线| 国内精品久久久久久久果冻传媒 | 欧美r片在线| 先锋影音国产一区| 中文一区字幕| 日韩亚洲精品视频| 欧美国产激情| 欧美+日本+国产+在线a∨观看| 亚洲欧美日韩在线观看a三区| 亚洲日本va午夜在线电影| 狠狠色丁香久久综合频道| 国产精品一区二区三区观看| 欧美人与禽猛交乱配| 免费亚洲网站| 久久午夜电影| 美女图片一区二区| 久久亚洲一区二区| 另类天堂av| 女女同性女同一区二区三区91| 久久精品亚洲一区二区三区浴池| 亚洲女性裸体视频| 中文av一区二区| 亚洲色图制服丝袜| 亚洲综合导航| 久久国产欧美精品| 久久九九久精品国产免费直播| 欧美在线资源| 久久精品日韩一区二区三区| 久久精品在这里| 久久永久免费| 欧美二区在线看| 欧美日韩成人| 国产精品视频九色porn| 国产精品一区二区在线观看不卡| 国产精品午夜av在线| 国产伦理一区| 影音先锋久久精品| 亚洲欧洲日产国产综合网| 夜夜嗨一区二区| 亚洲欧美另类久久久精品2019| 欧美在线视频日韩| 免费在线观看精品| 亚洲激情偷拍| 亚洲一区二区三区四区五区午夜| 亚洲综合欧美| 久久午夜精品一区二区| 欧美精品亚洲二区| 国产精品久久久久9999| 国产综合自拍| 日韩午夜黄色| 欧美伊人久久久久久久久影院| 另类激情亚洲| 日韩午夜电影在线观看| 午夜在线视频观看日韩17c| 另类图片国产| 国产精品午夜视频| 在线视频国内自拍亚洲视频| 在线亚洲电影| 老牛影视一区二区三区| 亚洲欧洲在线一区| 欧美在线免费视频| 欧美精品一区二区三区在线看午夜 | 亚洲国产经典视频| 99re视频这里只有精品| 欧美中文字幕不卡| 欧美日韩免费高清一区色橹橹| 国产午夜精品一区二区三区欧美 | 先锋影音网一区二区| 美女国产一区| 亚洲一区三区在线观看| 蜜臀久久99精品久久久画质超高清| 欧美性大战久久久久| 136国产福利精品导航网址| 午夜在线精品| 亚洲精选中文字幕| 久久亚洲精品中文字幕冲田杏梨| 国产精品婷婷| 亚洲一区二区视频在线观看| 欧美不卡在线视频| 久久国产天堂福利天堂| 国产精品久久久久久久久|