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

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 閱讀(427) 評論(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>
            久久亚洲高清| 欧美在线视频导航| 国产精品国产三级国产 | 久色婷婷小香蕉久久| 午夜精品一区二区三区在线播放| 夜夜嗨av一区二区三区中文字幕| 亚洲国产精品久久久久婷婷老年| 亚洲成人影音| 亚洲视频在线观看一区| 午夜视频久久久久久| 久久国产日韩| 亚洲高清一区二| 欧美激情亚洲国产| 日韩视频在线一区二区| 亚洲欧美激情视频| 你懂的视频欧美| 国产精品毛片a∨一区二区三区| 国产毛片一区| 亚洲欧洲一区二区三区在线观看| 一本色道婷婷久久欧美| 欧美制服丝袜| 亚洲日本成人女熟在线观看| 亚洲女人天堂av| 久久亚洲精品视频| 欧美日韩精品综合| 韩日在线一区| 亚洲在线视频| 欧美成人免费va影院高清| 亚洲九九精品| 久久婷婷av| 国产精品中文在线| 日韩写真视频在线观看| 久久中文久久字幕| 亚洲专区在线| 欧美日韩在线一区| 亚洲国产成人91精品| 欧美亚洲免费电影| 亚洲福利视频二区| 久久精品国产综合精品| 国产精品伦理| 亚洲欧美999| 亚洲精品乱码久久久久久蜜桃麻豆| 久久成人一区二区| 国产美女一区二区| 亚洲嫩草精品久久| 99国产麻豆精品| 欧美大片免费| 在线观看成人小视频| 亚洲欧洲99久久| 亚洲欧美日韩区| 亚洲一区二区三区免费视频| 欧美成人午夜影院| 亚洲高清三级视频| 美女精品自拍一二三四| 亚洲永久字幕| 国产精品毛片大码女人| 亚洲一区二区久久| av成人福利| 欧美午夜无遮挡| 一区二区三区你懂的| 亚洲精品视频一区二区三区| 欧美日韩国产经典色站一区二区三区| 亚洲日本成人网| 欧美高清在线| 欧美国产综合| 一本到12不卡视频在线dvd| 亚洲精品一二三区| 欧美日韩在线播| 中文在线不卡| 亚洲午夜三级在线| 国产精品视频男人的天堂| 小处雏高清一区二区三区| 亚洲中字在线| 1024成人网色www| 亚洲国产影院| 欧美精品日本| 亚洲在线观看免费视频| 亚洲你懂的在线视频| 狠狠色噜噜狠狠色综合久| 欧美高清在线播放| 国产精品videosex极品| 久久激情五月婷婷| 乱中年女人伦av一区二区| 一本久久综合亚洲鲁鲁| 亚洲永久在线| 亚洲精品在线电影| 亚洲一区二区精品| 国产一区二区黄色| 亚洲成色www久久网站| 欧美日韩色一区| 欧美主播一区二区三区| 久久男人av资源网站| 99ri日韩精品视频| 欧美一区二区三区婷婷月色 | 免费成人黄色片| 欧美久久久久久久| 久久精品九九| 欧美激情第二页| 亚洲欧美日韩国产综合在线| 亚洲欧美制服中文字幕| 亚洲黄色成人久久久| 亚洲视频在线观看一区| 悠悠资源网亚洲青| 一区二区三区久久精品| 狠狠色伊人亚洲综合网站色| 日韩一级大片| 亚洲国产小视频| 欧美一区二区三区电影在线观看| 亚洲综合日韩| 亚洲一区二区三区免费观看 | 欧美激情在线狂野欧美精品| 欧美日韩a区| 久久久最新网址| 欧美裸体一区二区三区| 久久裸体视频| 国产精品一卡二卡| 亚洲精品一区在线观看| 国内精品免费午夜毛片| 一本色道久久精品| 亚洲精品日本| 久久女同精品一区二区| 性欧美长视频| 欧美日韩在线不卡| 亚洲精品中文在线| 91久久精品视频| 久久免费偷拍视频| 久久精品一区| 国产日韩欧美一区二区三区四区| 91久久黄色| 亚洲二区视频| 久久免费观看视频| 久久免费精品视频| 国产一区二区三区高清在线观看| 亚洲视频在线观看| 亚洲在线视频| 国产精品老女人精品视频| 亚洲美女视频在线观看| 亚洲精品你懂的| 欧美成人午夜激情| 亚洲国产日韩在线一区模特| 在线免费观看日本欧美| 久久国产精品久久w女人spa| 久久经典综合| 国产欧美日韩专区发布| 亚洲欧美精品在线观看| 欧美一区三区三区高中清蜜桃| 欧美体内she精视频| 夜夜精品视频一区二区| 亚洲一级特黄| 国产毛片精品视频| 久久不射网站| 欧美成人免费全部观看天天性色| 在线观看欧美一区| 欧美成人午夜剧场免费观看| 一本久道久久综合中文字幕| 欧美激情二区三区| 91久久亚洲| 亚洲一区二区三区四区五区黄| 久久人人看视频| 91久久国产自产拍夜夜嗨| 久久精品导航| 国产一区二区三区在线观看免费视频| 亚洲欧美精品suv| 六月丁香综合| 亚洲精品美女免费| 国产精品高清网站| 性8sex亚洲区入口| 欧美成人一品| 亚洲在线观看视频| 国产精品美女999| 亚洲一区二区成人| 夜夜精品视频一区二区| 欧美在线关看| 国产午夜精品视频| 国产精品久久久久一区二区三区| 国产又爽又黄的激情精品视频| 亚洲日本中文字幕| 欧美大片一区二区三区| 91久久在线视频| 久久国产精品99国产| 在线视频观看日韩| 一本色道久久综合| 91久久精品国产91性色| 久久影院亚洲| 91久久国产综合久久| 国产精品久久午夜| 日韩天堂av| 欧美bbbxxxxx| 欧美日韩国产不卡| 在线亚洲高清视频| 亚洲欧洲另类| 欧美精品一区二区三区高清aⅴ| 国产精品免费观看在线| 精品动漫av| 欧美激情视频一区二区三区免费 | 久久人人97超碰国产公开结果| 亚洲裸体俱乐部裸体舞表演av| 另类专区欧美制服同性| 亚洲免费综合| 亚洲午夜成aⅴ人片|