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

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>
            欧美一区二区三区日韩| 香蕉免费一区二区三区在线观看 | 久久综合色婷婷| 猛男gaygay欧美视频| 蜜桃av噜噜一区| 亚洲国产你懂的| 亚洲国产一区二区三区在线播 | 午夜视频在线观看一区二区三区 | 久久资源在线| 欧美人妖在线观看| 国产精品午夜在线| 尤物在线精品| 在线亚洲伦理| 欧美中文在线视频| 亚洲国产精品电影| 亚洲一区二区三区四区在线观看 | 欧美二区在线| 在线一区二区三区四区| 久久成人精品无人区| 欧美不卡三区| 国产亚洲福利社区一区| 亚洲美女电影在线| 久久精品中文字幕一区二区三区| 欧美国产视频一区二区| 亚洲一区免费网站| 女同性一区二区三区人了人一| 国产精品成人午夜| 亚洲国产精品美女| 久久国产一区| 中文亚洲字幕| 欧美激情精品久久久六区热门 | 亚洲国产婷婷香蕉久久久久久| 国产精品99久久久久久人| 久久永久免费| 午夜精品久久久久久久久| 欧美日韩精品久久| 亚洲人久久久| 久热精品在线视频| 亚洲尤物视频网| 欧美色视频日本高清在线观看| 亚洲福利在线视频| 老巨人导航500精品| 亚洲欧美日韩综合| 国产精品美女久久久久久免费| 亚洲美女一区| 免费欧美在线视频| 久久久久久久久久久久久女国产乱 | 国产精品美女www爽爽爽| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美一区午夜视频在线观看| 亚洲人人精品| 欧美久久久久久| 日韩一二三在线视频播| 欧美福利电影在线观看| 久久亚洲欧美国产精品乐播| 激情久久中文字幕| 老司机午夜精品视频| 欧美一区二区三区喷汁尤物| 国产精品亚洲综合天堂夜夜| 亚洲欧美日韩专区| 亚洲永久精品国产| 国产日韩欧美中文| 久久精品一区二区三区四区| 欧美一区二区三区免费观看视频| 国产欧美日韩在线观看| 久久久久一区二区| 久久久免费av| 亚洲精品免费在线观看| 亚洲毛片在线看| 国产精品青草综合久久久久99 | 蜜桃久久av一区| 99精品视频免费观看| 亚洲美女在线视频| 国产精品入口尤物| 久久久久久久综合狠狠综合| 久久精品毛片| 99精品国产热久久91蜜凸| 一区二区三区久久网| 国产精品亚洲不卡a| 久久香蕉精品| 欧美精品在线视频| 欧美一区二区三区免费视频| 欧美一区二视频| 亚洲人成网站精品片在线观看| 日韩视频免费观看高清在线视频 | 免费看成人av| 欧美日韩精品免费| 欧美在线观看www| 噜噜噜91成人网| 亚洲永久在线| 一区二区三区久久久| 韩国在线视频一区| 亚洲免费观看在线观看| 国产午夜精品理论片a级探花 | 久久亚洲精品一区| 免费在线亚洲| 小黄鸭精品aⅴ导航网站入口| 欧美综合国产| 亚洲尤物在线| 美日韩精品视频| 欧美在线视频不卡| 欧美精品成人一区二区在线观看| 欧美在线日韩| 欧美日韩精品三区| 久久综合网色—综合色88| 欧美日韩日本国产亚洲在线| 久久久久久久激情视频| 欧美日韩精品一区二区在线播放 | 一区二区日韩精品| 在线日韩电影| 午夜精品久久久久久久久久久 | 欧美77777| 国产精品羞羞答答xxdd| 亚洲精品在线电影| 亚洲国产你懂的| 久久精品视频在线免费观看| 亚洲欧美国产制服动漫| 欧美精品videossex性护士| 免费不卡视频| 今天的高清视频免费播放成人| 99这里有精品| 日韩亚洲视频在线| 欧美精品久久99久久在免费线| 狂野欧美激情性xxxx欧美| 国产欧美va欧美va香蕉在| 99视频在线精品国自产拍免费观看 | 亚洲一级片在线观看| 一区二区欧美国产| 欧美精品成人一区二区在线观看| 免费视频最近日韩| 狠狠狠色丁香婷婷综合激情| 午夜一区在线| 久久久视频精品| 韩国成人理伦片免费播放| 欧美一区不卡| 久久久美女艺术照精彩视频福利播放| 国产精品热久久久久夜色精品三区| 亚洲免费福利视频| 亚洲女性喷水在线观看一区| 国产精品乱人伦一区二区| 亚洲伊人第一页| 久久成人av少妇免费| 国产真实乱偷精品视频免| 久久久精品国产免费观看同学| 狂野欧美一区| 亚洲精品一区二区三区蜜桃久| 欧美精品 日韩| 亚洲午夜极品| 久久一区欧美| 日韩视频在线一区二区| 欧美日韩国产免费| 亚洲视频中文| 久久综合网hezyo| 亚洲精品一二| 国产精品视频你懂的| 久久av资源网站| 亚洲黑丝在线| 亚洲欧美日韩在线不卡| 国产在线精品一区二区中文| 美女成人午夜| 中文在线一区| 农村妇女精品| 亚洲综合二区| 在线播放豆国产99亚洲| 欧美日本不卡高清| 午夜在线a亚洲v天堂网2018| 欧美大片一区二区| 先锋影音国产一区| 亚洲国产国产亚洲一二三| 欧美日韩成人在线播放| 欧美一区免费| 99精品视频网| 欧美xart系列高清| 午夜在线观看欧美| 亚洲欧洲日本在线| 国产三级欧美三级日产三级99| 美女在线一区二区| 亚洲欧美日韩中文视频| 亚洲激情综合| 久久久精品性| 亚洲影院污污.| 亚洲精品一品区二品区三品区| 国产伦精品一区二区三区照片91| 老司机免费视频一区二区三区 | 亚洲欧美日韩在线| 亚洲日本中文字幕| 久久伊人一区二区| 亚洲欧美日韩成人| 亚洲精品乱码久久久久久按摩观| 国产精品影视天天线| 欧美人妖在线观看| 美女图片一区二区| 久久成人精品| 午夜久久福利| 亚洲欧美春色| 亚洲在线视频观看| 夜夜爽av福利精品导航| 亚洲啪啪91| 亚洲福利专区| 欧美国产欧美综合|