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

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>
            国产一区二区精品久久| 亚洲午夜av| 99精品视频一区二区三区| 国产在线国偷精品产拍免费yy| 国产女同一区二区| 一本色道久久综合精品竹菊| 亚洲精品一区二区三区99| 亚洲另类一区二区| 亚洲视频中文| 欧美在线看片| 久久久久久久一区| 欧美黄色aaaa| 国产精品日本精品| 国外成人性视频| 亚洲国产精品激情在线观看| 日韩一级片网址| 欧美一区二区| 欧美韩日亚洲| 亚洲色在线视频| 久久av一区二区三区| 欧美高清自拍一区| 国产精品一区视频网站| 亚洲国产成人porn| 午夜精品久久久久久久男人的天堂 | 精品51国产黑色丝袜高跟鞋| 亚洲黄网站在线观看| 亚洲视频网在线直播| 玖玖综合伊人| 夜夜夜久久久| 欧美成人影音| 极品尤物av久久免费看| 亚洲永久精品大片| 欧美成人69| 中文国产亚洲喷潮| 另类国产ts人妖高潮视频| 亚洲精品在线视频| 免费观看在线综合色| 国产亚洲第一区| 亚洲一区二区三区免费视频| 久久亚洲国产成人| 中文欧美在线视频| 欧美国产在线视频| 亚洲第一精品夜夜躁人人躁 | 日韩亚洲欧美综合| 欧美va亚洲va香蕉在线| 亚洲女同在线| 国产精品国产a级| 夜夜狂射影院欧美极品| 久久一区激情| 久久aⅴ国产欧美74aaa| 国产乱码精品1区2区3区| 亚洲午夜一区二区三区| 亚洲激情啪啪| 老牛影视一区二区三区| 国产网站欧美日韩免费精品在线观看| 亚洲午夜国产一区99re久久| 亚洲精美视频| 欧美激情在线免费观看| 亚洲激情在线视频| 一区二区亚洲| 美女免费视频一区| 久久久噜噜噜久久狠狠50岁| 狠狠色狠狠色综合| 老司机久久99久久精品播放免费| 欧美在线观看视频| 狠狠色2019综合网| 免费在线看成人av| 美日韩免费视频| 亚洲精品影视| 国产欧美婷婷中文| 久久久精品久久久久| 久久成人免费| 在线观看欧美日本| 亚洲品质自拍| 国产精品久久999| 欧美影院午夜播放| 久久九九免费视频| 亚洲精选国产| 亚洲欧美激情四射在线日| 亚洲深夜福利| 国产免费亚洲高清| 欧美承认网站| 欧美激情第二页| 麻豆国产va免费精品高清在线| 欧美电影电视剧在线观看| 性久久久久久久久| 欧美激情中文字幕一区二区| 欧美专区在线观看| 日韩视频在线免费| 午夜伦欧美伦电影理论片| 激情综合在线| 亚洲精品社区| 国产一区999| 亚洲丶国产丶欧美一区二区三区| 欧美国内亚洲| 久久亚洲午夜电影| 欧美日韩国产在线| 久久久久久色| 欧美日韩久久| 免费久久99精品国产自在现线| 欧美精品在线观看播放| 久久黄色影院| 国产精品激情偷乱一区二区∴| 久久频这里精品99香蕉| 欧美日韩国产一区二区| 麻豆精品在线观看| 国产精品大全| 亚洲国产精品一区二区尤物区 | 国产精品成人一区二区三区夜夜夜 | 狠狠色丁香婷婷综合影院 | 久久青草久久| 午夜精品在线| 欧美人妖另类| 欧美成人a∨高清免费观看| 国产精品高潮在线| 亚洲日本电影| 欧美a级片网| 久久大逼视频| 国产精品不卡在线| 一区二区三区在线看| 中文一区二区| 亚洲精品永久免费精品| 久久免费国产| 久久久久国产精品一区| 国产精品夜夜夜| 亚洲午夜精品久久久久久浪潮| 99re这里只有精品6| 欧美 日韩 国产一区二区在线视频 | 玖玖综合伊人| 久久久久久伊人| 国产欧美婷婷中文| 性欧美在线看片a免费观看| 亚洲欧美福利一区二区| 欧美日韩国产美| 99精品热视频| 亚洲午夜精品久久久久久浪潮 | 亚洲大片免费看| 在线成人黄色| 免费毛片一区二区三区久久久| 久久婷婷综合激情| 合欧美一区二区三区| 久久五月天婷婷| 欧美成人高清| 亚洲精品护士| 欧美另类一区| 一区二区三区高清不卡| 亚洲一区二区精品| 国产嫩草影院久久久久| 午夜精品久久久久久久99黑人| 亚洲欧美日韩国产成人| 国产精品视频99| 久久久久久久久综合| 欧美成人自拍视频| 一区二区三区 在线观看视| 欧美性久久久| 欧美一二三视频| 欧美成人在线网站| 亚洲网站在线看| 国产午夜精品在线| 久久亚洲综合色一区二区三区| 欧美国产一区视频在线观看| 99ri日韩精品视频| 99亚洲一区二区| 欧美影院成人| 亚洲高清免费| 国产精品久久综合| 久久尤物电影视频在线观看| 亚洲欧洲一区二区在线播放| 亚洲制服少妇| 在线观看视频一区| 欧美日韩一区二区在线观看| 亚洲免费在线视频一区 二区| 久久夜色精品国产欧美乱极品| 亚洲精品一区二区三区福利| 国产精品高清在线| 久久在线免费| 中国成人黄色视屏| 亚洲国产成人av| 久久精品在线播放| 国产精品久久久久久久久久久久| 性亚洲最疯狂xxxx高清| 亚洲国产裸拍裸体视频在线观看乱了 | 樱桃成人精品视频在线播放| 欧美女同视频| 久久亚洲春色中文字幕| 亚洲天堂av综合网| 91久久精品视频| 久久免费视频在线观看| 一本色道久久综合| 在线看国产日韩| 国产日韩欧美在线播放| 欧美日韩国产首页在线观看| 久久免费高清视频| 欧美一区国产一区| 亚洲午夜极品| 中文在线资源观看网站视频免费不卡| 欧美韩国在线| 欧美fxxxxxx另类| 久久天堂成人| 欧美影院精品一区|