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

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一区| 亚洲国产日韩一区二区| 午夜伦欧美伦电影理论片| 另类av一区二区| 亚洲乱码一区二区| 国产偷国产偷亚洲高清97cao| 亚洲免费影视| 欧美a级片网| 午夜免费久久久久| 久久久久欧美精品| 亚洲一区区二区| 久久精品一区蜜桃臀影院| 一本色道久久综合亚洲精品不| 亚洲毛片视频| 久久久精品日韩| 在线一区二区日韩| 欧美影院一区| 国产精品久久久一区二区| 亚洲国产精品一区二区久| 亚洲一区欧美激情| 亚洲免费福利视频| 欧美国产在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎 | 牛牛影视久久网| 久久久精品tv| 精品91免费| 欧美亚洲一区二区在线观看| 久久综合国产精品| 日韩一级片网址| 老牛国产精品一区的观看方式| 午夜精品一区二区三区在线播放| 国产精品啊啊啊| 欧美一区二区三区在线视频| 久久国产精品99精品国产| 亚洲国产婷婷综合在线精品| 在线免费观看日本一区| 欧美成人a视频| 亚洲黄色成人| 久久―日本道色综合久久| 久久国产精品一区二区| 久久综合伊人77777| 免费高清在线视频一区·| 久久久久久久久一区二区| 国产一区二区激情| 欧美福利电影在线观看| 午夜免费久久久久| 最新国产乱人伦偷精品免费网站 | 毛片基地黄久久久久久天堂| 亚洲免费精彩视频| 国产日韩欧美综合在线| 国产精品婷婷| 久久在线免费观看视频| 国产美女精品视频| 老司机精品视频网站| 亚洲一区二区三区在线| 午夜在线一区二区| 亚洲精品一区在线观看香蕉| 销魂美女一区二区三区视频在线| 亚洲精品国精品久久99热| 国内成人在线| 国产女主播一区二区三区| 国产精品久久网站| 一区二区三区精品久久久| 欧美成人免费视频| 男女激情久久| 噜噜爱69成人精品| 免费视频久久| 中文在线一区| 香蕉亚洲视频| 欧美在线亚洲综合一区| 久久精品动漫| 欧美一区中文字幕| 久久av最新网址| 久久午夜电影| 亚洲日韩视频| 午夜精品久久久久久久男人的天堂 | 欧美高清在线视频| 亚洲成色www8888| 亚洲国产一区二区精品专区| 在线性视频日韩欧美| 亚洲综合不卡| 欧美国产日韩一区二区| 国产精品入口| 亚洲国产成人高清精品| 亚洲每日更新| 免费成人高清视频| 亚洲人成网在线播放| 亚洲中午字幕| 亚洲黄网站在线观看| 亚洲午夜av| 香蕉av福利精品导航| 欧美一区二区日韩一区二区| 欧美大片一区| 欧美在线二区| 国产精品99免费看| av不卡在线| 欧美二区在线观看| 亚洲欧美日韩一区二区| 欧美午夜免费影院| 亚洲视频一区| 亚洲乱码精品一二三四区日韩在线| 欧美在线视频观看| 宅男噜噜噜66一区二区| 欧美激情综合在线| 亚洲美女在线观看| 亚洲精品日韩久久| 亚洲伦理在线| 久久久久久久网| 欧美在线观看一二区| 国产一区二区三区久久久| 久久婷婷国产麻豆91天堂| 欧美一区二区视频97| 国产亚洲毛片在线| 免费久久精品视频| 欧美欧美全黄| 亚洲精品在线免费观看视频| 亚洲精品日韩欧美| 欧美综合第一页| 亚洲午夜在线观看| 久久精品日产第一区二区三区 | 国产日韩精品在线观看| 中文精品一区二区三区 | 欧美性一二三区| 欧美国产另类| 国产欧美亚洲精品| 日韩视频一区二区在线观看| 最新中文字幕一区二区三区| 欧美91福利在线观看| 国产精品捆绑调教| 亚洲日韩成人| 欧美一区二区播放| 亚洲曰本av电影| 欧美理论电影在线观看| 欧美国产成人精品| 在线观看中文字幕不卡| 在线观看视频亚洲| 日韩一二三区视频| 亚洲女性裸体视频| 国产日韩欧美一区| 久久免费黄色| 亚洲第一主播视频| 99精品久久免费看蜜臀剧情介绍| 六十路精品视频| 亚洲国产精品尤物yw在线观看| 91久久国产精品91久久性色| 欧美激情精品久久久久久久变态 | 午夜日韩av| 亚洲在线观看免费| 久久久久久有精品国产| 久久久人成影片一区二区三区| 国产三区二区一区久久| 久久精品国产久精国产思思| 欧美成人黄色小视频| 亚洲精品一区二区三区婷婷月| 国产精品第一区| 久久亚洲精选| 午夜视频在线观看一区二区三区| 久久免费视频在线| 夜久久久久久| 在线看欧美日韩| 国产欧美激情| 欧美午夜不卡| 亚洲人成艺术| 暖暖成人免费视频| 欧美中文日韩| 亚洲欧美电影院| 亚洲精品网站在线播放gif| 久久综合久久综合久久综合| 海角社区69精品视频| 国产麻豆精品视频| 亚洲午夜在线观看| 午夜精品视频在线| 亚洲国产精品黑人久久久| 一区二区亚洲欧洲国产日韩| 日韩小视频在线观看| 亚洲影视中文字幕| 亚洲欧美日韩国产综合| 亚洲新中文字幕| 欧美一区综合| 亚洲精品资源| 宅男精品导航| 久久精品二区三区| 欧美激情一区二区三区蜜桃视频| 亚洲三级免费电影| 亚洲色图自拍| 久久久精品日韩| 性色av一区二区三区| 亚洲电影有码| 欧美一区二区三区精品| 久久久久一本一区二区青青蜜月| 日韩视频永久免费| 欧美成人日韩| 欧美激情一区二区三区四区| 国产一区二区日韩精品欧美精品 | 乱码第一页成人| 国产婷婷一区二区|