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

Code Knight

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

一道面試題

最近面試遇到一道很懷念的題目,約瑟夫環,由于代碼較多沒有當時寫在卷上,說了說思路,下來用模板實現了一下,使用雙向循環鏈表,每到第五個kick out。
注:模板未考慮非常規自定義類型的淺拷貝問題;另外代碼沒有優化,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// 數到第五個人出局
    {
        
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++與編程之道


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            亚洲人成欧美中文字幕| 欧美国产欧美亚州国产日韩mv天天看完整| 国产精品爱久久久久久久| 久久国产福利| 国产精品女主播| 亚洲国产精品一区制服丝袜| 久久久久免费观看| 欧美亚男人的天堂| 欧美久久久久免费| 亚洲视频免费看| 蜜桃久久av一区| 极品少妇一区二区三区精品视频| 亚洲欧美日韩视频二区| 久久影视精品| 午夜日韩在线观看| 亚洲精品美女久久久久| 欧美激情视频一区二区三区在线播放 | 99精品热视频| 欧美日韩免费观看一区| 午夜精品久久久久久久99黑人| 亚洲综合视频一区| 99re热这里只有精品免费视频| 午夜日韩福利| 欧美国产成人在线| 看欧美日韩国产| 久久天天狠狠| 亚洲视频在线观看一区| 亚洲精品国产精品国产自| 亚洲精品少妇网址| 欧美国产在线电影| 欧美成年人在线观看| 久久国产夜色精品鲁鲁99| 夜夜爽99久久国产综合精品女不卡| 国产精品国码视频| 欧美精品首页| 激情久久中文字幕| 久久www成人_看片免费不卡| 日韩一级黄色大片| 欧美色123| 国产视频一区欧美| 国产精品成人播放| 亚洲欧美视频在线| 亚洲在线第一页| 亚洲欧美在线aaa| 国产精品久久久久一区二区三区共| 亚洲午夜极品| 午夜影院日韩| 欧美成人免费网站| 欧美日本成人| 久久都是精品| 欧美国产精品v| 亚洲网在线观看| 久久夜色撩人精品| 欧美精品色综合| 亚洲欧美综合一区| 欧美一区二区三区在线观看视频 | 久久青青草原一区二区| 老牛国产精品一区的观看方式| 欧美成人精品一区二区| 欧美性大战久久久久久久蜜臀| 免费成年人欧美视频| 国产精品扒开腿爽爽爽视频| 久久av老司机精品网站导航 | 午夜免费久久久久| 久久精品日产第一区二区| 欧美日韩国产麻豆| 亚洲激情不卡| 久久香蕉国产线看观看av| 欧美日韩国产精品一区二区亚洲| 久久久国产亚洲精品| 亚洲人成网站999久久久综合| 亚洲一线二线三线久久久| 在线日韩av片| 久久精品视频在线看| 欧美日本免费| 亚洲国产一二三| 亚洲国产日韩欧美| 看片网站欧美日韩| 蜜臀av一级做a爰片久久 | 欧美大尺度在线| 美女日韩在线中文字幕| 国产亚洲激情视频在线| 欧美日韩精品不卡| 一本色道久久加勒比精品| 欧美看片网站| 99国产精品久久| 国产乱理伦片在线观看夜一区 | 免费在线看一区| 亚洲精品一区二区三区不| 欧美α欧美αv大片| 亚洲欧洲一区二区在线观看| 国产精品久久九九| 亚洲一区二区高清视频| 欧美日韩精品在线视频| 亚洲欧美综合另类中字| 老鸭窝亚洲一区二区三区| 亚洲国产精品久久| 亚洲美女av黄| 亚洲成人在线网| 欧美精品一区三区| 欧美一进一出视频| 99国产欧美久久久精品| 浪潮色综合久久天堂| 一区二区三区国产盗摄| 嫩模写真一区二区三区三州| 亚洲欧洲视频| 美女视频网站黄色亚洲| 正在播放亚洲| 亚洲日韩第九十九页| 影音先锋亚洲一区| 久久狠狠久久综合桃花| 欧美影视一区| 国产亚洲欧美色| 国产欧美日韩不卡| 久久九九国产| 久久精品国产亚洲一区二区三区| 亚洲一级在线| 午夜精品免费在线| 欧美一区二区三区在线视频| 一道本一区二区| 亚洲午夜免费福利视频| 在线视频欧美一区| 亚洲午夜在线视频| 欧美一乱一性一交一视频| 一区二区av在线| 欧美亚洲网站| 久久综合图片| 欧美高潮视频| 亚洲一区二区三区免费观看| 亚洲欧美日韩国产中文在线| 久久av免费一区| 亚洲人成人77777线观看| 欧美三日本三级少妇三99| 国产精品丝袜xxxxxxx| 久久久久在线观看| 亚洲网站在线观看| 久久久久久亚洲精品杨幂换脸| 欧美1区免费| 国产乱码精品一区二区三区不卡| 国产目拍亚洲精品99久久精品| 揄拍成人国产精品视频| 一本色道久久88综合亚洲精品ⅰ| 亚洲欧美国产另类| 亚洲色图在线视频| 免费在线看一区| 亚洲欧美日韩一区二区三区在线观看| 久久天天狠狠| 久久久久久网址| 国产亚洲aⅴaaaaaa毛片| 一区二区三区国产在线| 亚洲高清在线观看| 蘑菇福利视频一区播放| 亚洲午夜av在线| 欧美日韩色综合| 一区二区av在线| 亚洲美女色禁图| 欧美女主播在线| 亚洲一区二区三区四区五区黄| 亚洲缚视频在线观看| 欧美激情精品久久久久久久变态| 在线免费观看一区二区三区| 久久免费黄色| 欧美刺激午夜性久久久久久久| 99re6热只有精品免费观看 | 99热精品在线| 亚洲精品免费一区二区三区| 欧美日韩亚洲一区二区三区在线观看| 日韩视频在线免费| 中文精品一区二区三区| 国产欧美日韩综合一区在线观看| 亚洲午夜一区二区| 在线免费不卡视频| 亚洲午夜精品一区二区| 亚洲欧美综合另类中字| 亚洲高清视频一区二区| 亚洲视频综合| 亚洲最新合集| 亚洲承认在线| 亚洲在线中文字幕| 国产一区二区欧美日韩| 激情欧美亚洲| 亚洲欧美一区二区三区久久| 欧美一区二视频在线免费观看| 国产精品成人国产乱一区| 欧美亚洲免费| 久久综合网色—综合色88| 亚洲韩国日本中文字幕| 欧美日韩综合在线| 久久久国产精品一区二区三区| 亚洲精品一区二区三区福利| 亚洲国产精品一区二区久| 久久精品在线观看| 亚洲高清在线精品| 亚洲视频在线观看免费| 国产精品亚洲精品| 久久久久一区二区| 亚洲日本欧美在线| 亚洲欧美中文字幕| 亚洲电影在线播放| 欧美午夜激情视频|