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

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>
            午夜精品久久久久久久久久久久久| 欧美国产成人精品| 欧美日韩亚洲精品内裤| 久久亚洲风情| 久久xxxx精品视频| 午夜在线不卡| 先锋影音久久| 欧美一区二区高清| 久久高清免费观看| 久热这里只精品99re8久| 久久一区二区三区国产精品| 亚洲网站视频| 亚洲一二区在线| 欧美一区二区三区播放老司机| 亚洲综合精品| 欧美伊人久久久久久午夜久久久久| 亚洲一区图片| 久久久国产精品一区| 另类天堂视频在线观看| 欧美日产在线观看| 国产欧美 在线欧美| 国产综合色产在线精品| 亚洲欧洲在线免费| 亚洲一区在线观看视频| 久久精品99无色码中文字幕| 久久这里只有| 亚洲一区二区三区精品在线观看| 亚洲最快最全在线视频| 亚洲欧美日本精品| 另类春色校园亚洲| 欧美视频日韩视频| 国产在线视频欧美一区二区三区| 午夜久久久久久| 久久亚洲国产精品一区二区| 欧美日韩国产一中文字不卡 | 在线播放精品| 亚洲少妇最新在线视频| 欧美在线地址| 亚洲黄色精品| 亚洲人久久久| 欧美在线播放一区二区| 欧美精品高清视频| 黄色一区二区在线| 亚洲免费在线| 亚洲国产精品精华液2区45| 亚洲欧美视频在线| 欧美经典一区二区三区| 在线免费观看日本一区| 久久av一区二区三区漫画| 一本到高清视频免费精品| 牛夜精品久久久久久久99黑人| 国产午夜一区二区三区| 性色av一区二区三区红粉影视| 亚洲三级毛片| 你懂的国产精品| 亚洲国产精品久久久久秋霞蜜臀| 久久精品观看| 午夜欧美精品久久久久久久| 国产精品久久久99| 亚洲综合视频一区| 亚洲午夜视频在线| 国产精品日本| 亚洲一级在线| 亚洲精品一区中文| 欧美二区在线观看| 在线看国产日韩| 蜜臀久久99精品久久久久久9 | 欧美一区二区成人6969| 亚洲男人av电影| 亚洲欧洲免费视频| 欧美激情在线观看| 欧美午夜视频网站| 国产一区在线免费观看| 亚洲国产mv| 亚洲视频1区2区| 久久久国产精品一区二区中文| 亚洲黄色高清| 欧美日韩色一区| 国产精品嫩草影院一区二区| 国产精品红桃| 一区三区视频| 国产精品久久| 久久精品欧美日韩| 欧美激情精品久久久久久| 亚洲国产精品福利| 欧美一级久久久| 欧美黄免费看| 国产精品亚洲激情| 欧美片第1页综合| 亚洲综合色丁香婷婷六月图片| 久久国产精品免费一区| 亚洲国产91精品在线观看| 亚洲欧美日韩国产中文在线| 麻豆视频一区二区| 国产精品永久在线| 99成人精品| 欧美成人午夜激情| 欧美一级视频| 亚洲国产精品国自产拍av秋霞| 欧美午夜电影网| 亚洲美女av网站| 久久一区二区三区av| 中文在线一区| 欧美伦理在线观看| 亚洲国产天堂久久综合网| 久久国产婷婷国产香蕉| 亚洲欧美日韩综合| 亚洲欧美一区二区三区极速播放| 日韩一级黄色av| 男女视频一区二区| 1024精品一区二区三区| 久久精品国产亚洲高清剧情介绍| 亚洲精品一二三| 欧美成年人网站| 亚洲国产三级| 亚洲一区影音先锋| 女女同性精品视频| 亚洲激情综合| 欧美成人精品一区| 久久久久久久网站| 1204国产成人精品视频| 免费成人av在线看| 久久久免费av| 欧美精品日韩三级| 欧美黄色免费| 欧美国产欧美综合| 亚洲狼人精品一区二区三区| 欧美国产欧美亚州国产日韩mv天天看完整| 亚洲欧美激情视频在线观看一区二区三区| 欧美日韩一区二区三区视频| 亚洲少妇最新在线视频| 亚洲一区二区三区高清不卡| 国产老女人精品毛片久久| 国产精品99久久久久久有的能看| 国产精品福利在线| 欧美视频在线观看 亚洲欧| 欧美精品麻豆| 这里只有精品视频| 亚洲图片欧洲图片日韩av| 亚洲高清三级视频| 激情国产一区二区| 亚洲第一精品夜夜躁人人爽| 99热免费精品在线观看| 国产一区清纯| 国产欧美日韩一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在 | 狂野欧美一区| 欧美国产日本在线| 亚洲无亚洲人成网站77777| 亚洲香蕉在线观看| 一区二区三区中文在线观看| 亚洲国产精品一区二区第一页| 久久婷婷蜜乳一本欲蜜臀| 玖玖国产精品视频| 欧美日韩一区二区国产| 久久久久久婷| 欧美日韩国产小视频在线观看| 久久成人精品| 欧美美女操人视频| 久久人体大胆视频| 亚洲日本中文字幕区| 亚洲天堂av在线免费| 永久91嫩草亚洲精品人人| 夜夜爽夜夜爽精品视频| 国产一区二区丝袜高跟鞋图片| 欧美激情在线免费观看| 国产精品久久久久久久久久免费 | 精品白丝av| 99精品国产在热久久| 极品尤物一区二区三区| 欧美一区二区视频观看视频| 欲香欲色天天天综合和网| 亚洲视频一二| 亚洲精品视频在线| 欧美在线日韩精品| 亚洲淫性视频| 欧美极品色图| 欧美国产一区二区| 欧美国产日韩二区| 国产日韩欧美麻豆| 欧美高清在线视频| 久久综合国产精品| 国产精品美女久久久浪潮软件 | 久久综合伊人77777麻豆| 亚洲免费在线视频一区 二区| 欧美va天堂在线| 国产精品第十页| 久久综合一区| 国产日韩欧美精品一区| 在线一区免费观看| 欧美日韩午夜剧场| 亚洲性图久久| 国产精品午夜国产小视频| 99成人精品| 日韩一级片网址| 免费欧美网站| 一区二区国产在线观看| 国产日韩欧美高清| 先锋资源久久| 欧美一级视频|