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

Code Knight

Programming is so cool
隨筆 - 52, 文章 - 0, 評論 - 14, 引用 - 0
數(shù)據(jù)加載中……

一道面試題

最近面試遇到一道很懷念的題目,約瑟夫環(huán),由于代碼較多沒有當(dāng)時寫在卷上,說了說思路,下來用模板實現(xiàn)了一下,使用雙向循環(huán)鏈表,每到第五個kick out。
注:模板未考慮非常規(guī)自定義類型的淺拷貝問題;另外代碼沒有優(yōu)化,delnode效率有提升空間,有興趣的改改看。

  1template<class T>
  2struct SNode
  3{
  4    SNode(T dNode)
  5    {
  6        dData = dNode;
  7    }

  8    T dData;
  9    SNode<T>* pNext;
 10    SNode<T>* pPre;
 11}
;
 12
 13template<class T>
 14class CDoubleList
 15{
 16public:
 17    CDoubleList(T dDode);
 18    ~CDoubleList();
 19public:
 20    bool AddNode(T dNode);
 21    SNode<T>* DelNode(T dNode);
 22    int  GetSize(){return m_nListSize;}
 23    void PrintList();
 24
 25    SNode<T>* GetHead(){return m_pHead;}
 26private:
 27    SNode<T>* m_pHead;
 28    SNode<T>* m_pTail;
 29
 30    int          m_nListSize;
 31}
;
 32
 33template<class T>
 34CDoubleList<T>::CDoubleList(T dHead):m_nListSize(0)
 35{
 36    m_pHead = new SNode<T>(dHead);
 37    if(!m_pHead)
 38    {
 39        // error
 40        return;
 41    }

 42
 43    m_pTail = m_pHead;
 44    m_pHead->pPre = m_pTail;
 45    m_pHead->pNext = m_pTail;
 46    m_pTail->pPre = m_pHead;
 47    m_pTail->pNext = m_pHead;
 48
 49    ++m_nListSize;
 50}

 51
 52template<class T>
 53CDoubleList<T>::~CDoubleList()
 54{
 55    SNode<T>* pStart = m_pHead;
 56    for(int i = 0; i < m_nListSize; ++i)
 57    {
 58        DelNode(pStart->dData);
 59    }

 60}

 61
 62template<class T>
 63bool CDoubleList<T>::AddNode(T dNode)
 64{
 65    if(GetSize() < 1)
 66        return false;
 67
 68    SNode<T>* pNewNode = new SNode<T>(dNode);
 69    pNewNode->pPre = m_pTail;
 70    pNewNode->pNext = m_pTail->pNext;
 71    m_pTail->pNext = pNewNode;
 72    pNewNode->pNext->pPre = pNewNode;
 73
 74    m_pTail = pNewNode;
 75
 76    ++m_nListSize;
 77
 78    return true;
 79}

 80
 81template <class T>
 82SNode<T>* CDoubleList<T>::DelNode(T dNode)
 83{
 84    static SNode<T>* pNode = m_pHead;
 85    // 遍歷,找到相同的刪除
 86    for(int i = 0; i < m_nListSize; ++i)
 87    {
 88        if(pNode->dData == dNode)
 89        {
 90            if(pNode == m_pHead)
 91            {
 92                // 刪除頭,特殊處理
 93                pNode->pPre->pNext = pNode->pNext;
 94                pNode->pNext->pPre = pNode->pPre;
 95
 96                m_pTail = pNode->pPre;
 97
 98                SNode<T>* pNewNode = pNode->pNext;
 99                delete pNode;
100
101                pNode = pNewNode;
102
103                m_pHead = pNode;
104
105                --m_nListSize;
106                return m_pHead;
107            }

108            else
109            {
110                pNode->pPre->pNext = pNode->pNext;
111                pNode->pNext->pPre = pNode->pPre;
112
113                SNode<T>* pNewNode = pNode->pNext;
114                delete pNode;
115
116                pNode = pNewNode;
117
118                --m_nListSize;
119
120                return pNode;
121            }

122        }

123
124        pNode = pNode->pNext;
125    }

126
127    return 0;
128}

129
130
131template <class T>
132void CDoubleList<T>::PrintList()
133{
134    SNode<T>* pNode = m_pHead;
135    for(int i = 0; i < m_nListSize; ++i)
136    {    
137        cout<<pNode->dData<<endl;
138
139        pNode = pNode->pNext;
140    }

141}
#include "list.h"
#include 
<iostream>
using namespace std;

void main()
{
    CDoubleList
<int> dList(1);
    
for(int i = 2; i < 10++i)
    
{
            dList.AddNode(i);
    }

    dList.PrintList();
    cout
<<"begin do something"<<endl;

    SNode
<int>* pStart= dList.GetHead();
    
while(dList.GetSize() != 1// 數(shù)到第五個人出局
    {
        
for(int i = 0; i < 4++i)
        
{
            
if(!pStart)
            
{
                
//error
            }


            pStart 
= pStart->pNext;
        }


        pStart 
= dList.DelNode(pStart->dData);
    }


    dList.PrintList();
    cout
<<"magic end"<<endl;

    getchar();
}

posted on 2010-04-12 15:55 Code Knight 閱讀(358) 評論(0)  編輯 收藏 引用 所屬分類: C++與編程之道


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久综合精品| 国产精品日韩欧美一区二区| 久久久久在线| 欧美中文在线观看| 亚洲欧美日韩精品一区二区| 亚洲一区二区三区精品在线| 亚洲私拍自拍| 亚洲欧美日韩在线观看a三区| 午夜电影亚洲| 久久精品中文字幕免费mv| 久久久精品一区| 亚洲电影免费| 亚洲国产精品视频| 一本色道婷婷久久欧美| 亚洲自拍偷拍视频| 久久一区二区三区四区五区| 欧美区亚洲区| 国产精品视频一二三| 狠狠色丁香久久综合频道 | 亚洲一区二区三区三| 欧美一级大片在线免费观看| 猫咪成人在线观看| 国产精品久久久久久久久久久久久久| 国产精品一区免费在线观看| 亚洲电影第三页| 亚洲一区日韩在线| 免费久久精品视频| 国产欧美亚洲精品| 久久先锋影音av| 国产精品久久777777毛茸茸| 韩国久久久久| 中文精品视频一区二区在线观看| 久久精品国产91精品亚洲| 欧美激情中文字幕乱码免费| 这里只有视频精品| 美国成人直播| 国产性做久久久久久| 一本色道久久综合亚洲二区三区| 久久国产免费| 99国产精品久久久| 欧美a级一区| 黄色精品在线看| 欧美一区国产一区| 日韩视频永久免费| 免费日韩视频| 影音先锋久久资源网| 亚洲综合丁香| 亚洲免费观看视频| 欧美激情网友自拍| 亚洲国产成人tv| 久久综合色综合88| 久久精品成人一区二区三区| 国产欧美日韩视频一区二区三区| 亚洲午夜激情在线| 一本一本a久久| 国产精品国码视频| 亚洲一区二区三区在线视频| 欧美激情精品久久久| 亚洲欧美国产毛片在线| 欧美激情精品久久久久久久变态| 好吊妞**欧美| 久久久久久久久久看片| 欧美在线播放一区二区| 国产亚洲欧美一区在线观看| 久久精品人人做人人综合| 亚洲在线成人精品| 国产欧美不卡| 久久久久综合网| 美女脱光内衣内裤视频久久网站| 一区精品在线播放| 欧美v国产在线一区二区三区| 久久视频这里只有精品| 亚洲第一精品电影| 亚洲国产日韩在线一区模特| 欧美激情精品久久久久久变态| 亚洲久久一区| 99热这里只有精品8| 国产精品久久久久久久午夜| 欧美亚洲在线视频| 欧美一区二区三区免费在线看| 国产午夜精品视频免费不卡69堂| 久久深夜福利| 欧美激情1区2区3区| 亚洲一级黄色| 欧美一区二区高清| 亚洲人成人一区二区三区| 亚洲韩日在线| 亚洲一区在线直播| 亚洲欧美国产视频| 激情久久五月| 亚洲人精品午夜| 国产伦精品一区二区三区在线观看 | 亚洲第一黄网| 欧美日韩亚洲免费| 久久爱另类一区二区小说| 久久尤物电影视频在线观看| 夜夜嗨av色一区二区不卡| 亚洲欧美日韩一区在线| 亚洲国产一区二区三区在线播 | 亚洲无玛一区| 欧美在线一二三| 洋洋av久久久久久久一区| 亚洲伊人伊色伊影伊综合网| 亚洲电影免费观看高清完整版在线| 亚洲欧洲一区二区天堂久久| 国产精品久久久久毛片软件| 欧美成人综合| 国产日本欧美一区二区三区| 亚洲国产成人精品久久| 国产精品一区亚洲| 亚洲激情国产精品| 国产在线精品成人一区二区三区 | 小嫩嫩精品导航| 蜜桃视频一区| 久久久久久久高潮| 国产精品成人免费| 亚洲福利专区| 国内一区二区在线视频观看| 99精品久久久| 亚洲精品美女免费| 久久精品亚洲一区二区| 亚洲免费在线电影| 欧美激情在线狂野欧美精品| 久久亚洲春色中文字幕| 国产精品一区二区久久| 一区二区三区国产精品| 日韩午夜视频在线观看| 免费成人在线视频网站| 久久午夜电影网| 国产午夜精品美女毛片视频| 亚洲一区二区在线播放| 亚洲午夜黄色| 欧美午夜精品一区二区三区| 亚洲日本电影在线| 日韩视频在线免费观看| 亚洲精品乱码久久久久久黑人| 女人香蕉久久**毛片精品| 欧美一级成年大片在线观看| 国产精品qvod| 亚洲一二三区视频在线观看| 中文亚洲视频在线| 欧美日韩色一区| 亚洲九九精品| 一区二区高清视频| 欧美日韩在线精品| 一区二区三区 在线观看视| 一区二区久久| 欧美日韩视频| 亚洲午夜极品| 久久精品国产99精品国产亚洲性色| 国产精品男女猛烈高潮激情| 亚洲自拍16p| 久久综合中文字幕| 亚洲国产日韩欧美在线99| 欧美国产一区在线| 一片黄亚洲嫩模| 久久精品国产亚洲高清剧情介绍| 国产日韩欧美成人| 久久久久久久久蜜桃| 亚洲国产精品精华液2区45| 一区二区免费看| 国产欧亚日韩视频| 老**午夜毛片一区二区三区| 亚洲美女av黄| 久久精品亚洲一区二区三区浴池| 精品动漫3d一区二区三区免费| 免费久久久一本精品久久区| 亚洲精一区二区三区| 久久精品二区三区| 亚洲人成小说网站色在线| 欧美无乱码久久久免费午夜一区| 亚洲综合二区| 亚洲福利在线观看| 欧美一区亚洲二区| 亚洲国产你懂的| 国产精品福利片| 久久久久久久久久久一区| 亚洲三级电影在线观看| 欧美亚洲一级片| 日韩视频在线免费| 国内外成人免费视频 | 欧美激情1区2区| 新片速递亚洲合集欧美合集| 欧美黑人在线播放| 欧美在线观看视频| 一二三四社区欧美黄| 国产一区二区三区四区在线观看 | 国产一区二区三区久久 | 精品粉嫩aⅴ一区二区三区四区| 欧美成人一区二区| 午夜在线电影亚洲一区| 最新日韩在线视频| 久久综合九色综合欧美就去吻| 日韩午夜电影| 亚洲韩国一区二区三区| 国产一区二区三区在线观看免费视频| 欧美日韩不卡| 欧美高清日韩| 亚洲愉拍自拍另类高清精品| 韩国av一区二区三区在线观看|