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

life02

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  197 隨筆 :: 3 文章 :: 37 評論 :: 0 Trackbacks
http://www.cnblogs.com/iceocean/articles/1775848.html

題目:輸入一個鏈表的頭結點,反轉該鏈表,并返回反轉后鏈表的頭結點。鏈表結點定義如下:
struct ListNode
{
      int        m_nKey;
       ListNode* m_pNext;
};
分析:這是一道廣為流傳的微軟面試題。由于這道題能夠很好的反應出程序員思維是否嚴密,在微軟之后已經有很多公司在面試時采用了這道題。
為了正確地反轉一個鏈表,需要調整指針的指向。與指針操作相關代碼總是容易出錯的,因此最好在動手寫程序之前作全面的分析。在面試的時候不急于動手而是一開始做仔細的分析和設計,將會給面試官留下很好的印象,因為在實際的軟件開發中,設計的時間總是比寫代碼的時間長。與其很快地寫出一段漏洞百出的代碼,遠不如用較多的時間寫出一段健壯的代碼。
為了將調整指針這個復雜的過程分析清楚,我們可以借助圖形來直觀地分析。假設下圖中lmn是三個相鄰的結點:
aßbßßl  mànà
假設經過若干操作,我們已經把結點l之前的指針調整完畢,這些結點的m_pNext指針都指向前面一個結點。現在我們遍歷到結點m。當然,我們需要把調整結點的m_pNext指針讓它指向結點l。但注意一旦調整了指針的指向,鏈表就斷開了,如下圖所示:
aßbßlßm  nà
因為已經沒有指針指向結點n,我們沒有辦法再遍歷到結點n了。因此為了避免鏈表斷開,我們需要在調整mm_pNext之前要把n保存下來。
接下來我們試著找到反轉后鏈表的頭結點。不難分析出反轉后鏈表的頭結點是原始鏈表的尾位結點。什么結點是尾結點?就是m_pNext為空指針的結點。
基于上述分析,我們不難寫出如下代碼:
///////////////////////////////////////////////////////////////////////
// Reverse a list iteratively
// Input: pHead - the head of the original list
// Output: the head of the reversed head
///////////////////////////////////////////////////////////////////////
ListNode* ReverseIteratively(ListNode* pHead)
{
       ListNode* pReversedHead = NULL;
       ListNode* pNode = pHead;
       ListNode* pPrev = NULL;
      while(pNode != NULL)
       {
            // get the next node, and save it at pNext
             ListNode* pNext = pNode->m_pNext;
            // if the next node is null, the currect is the end of original
            // list, and it's the head of the reversed list
            if(pNext == NULL)
                   pReversedHead = pNode;

            // reverse the linkage between nodes
             pNode->m_pNext = pPrev;

            // move forward on the the list
             pPrev = pNode;
             pNode = pNext;
       }

      return pReversedHead;
}
(轉載

List ReverseList(List head)  
{  
    
if(head->next == NULL || head->next->next == NULL)    
    
{  
       
return head;   /*鏈表為空或只有一個元素則直接返回*/  
    }
  
  
    ListNode 
*= NULL,  
             
*= head->next,  
             
*= head->next->next;  
    
while(q != NULL)  
    
{          
      t 
= q->next;  
      q
->next = p;  
      p 
= q;  
      q 
= t;  
    }
  
  
    
/*此時q指向原始鏈表最后一個元素,也是逆轉后的鏈表的表頭元素*/  
    head
->next->next = NULL;  /*設置鏈表尾*/  
    head
->next = p;           /*調整鏈表頭*/  
    
return head;  
}
  
  


posted on 2012-02-21 16:32 life02 閱讀(433) 評論(0)  編輯 收藏 引用 所屬分類: 筆試
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久精品午夜少妇| 国产亚洲一级| 日韩视频―中文字幕| 亚洲国产精品黑人久久久| 久久久www免费人成黑人精品| 亚洲欧美另类国产| 欧美一区网站| 欧美激情久久久| 亚洲久色影视| 亚洲欧美日韩精品一区二区| 欧美影院成人| 欧美大片免费| 国产精品久久久久一区二区| 国产一区二区三区在线观看视频| 一区精品久久| 99在线精品观看| 欧美主播一区二区三区| 欧美aⅴ99久久黑人专区| 亚洲人成人一区二区三区| 在线一区二区三区四区| 久久另类ts人妖一区二区| 国产精品hd| 亚洲国产精品va在线观看黑人| 亚洲一区二区三区免费在线观看| 久久久www成人免费无遮挡大片| 亚洲全部视频| 久久久综合网站| 国产伦理一区| 中国成人在线视频| 欧美国产日韩xxxxx| 亚洲综合精品一区二区| 欧美高清视频在线观看| 国产一区再线| 亚洲一区国产精品| 亚洲高清一区二区三区| 久久精品道一区二区三区| 国产精品久久久久av免费| 亚洲国内欧美| 久久蜜桃精品| 亚洲在线网站| 国产精品99一区二区| 日韩图片一区| 欧美大片免费观看| 久久精品欧美日韩精品| 国产嫩草一区二区三区在线观看| 99国产精品99久久久久久| 欧美成人a视频| 久久精品人人爽| 国产一区二区三区四区五区美女| 亚洲天堂av在线免费| 亚洲国产你懂的| 蜜臀va亚洲va欧美va天堂| 激情亚洲成人| 久久亚洲春色中文字幕| 欧美一区二视频在线免费观看| 欧美无乱码久久久免费午夜一区| 午夜视频在线观看一区二区三区| 日韩视频欧美视频| 欧美国产亚洲视频| 亚洲国产中文字幕在线观看| 免费试看一区| 免费成人高清| 亚洲靠逼com| 亚洲黄色有码视频| 欧美黄色影院| 中文欧美字幕免费| 日韩一二三区视频| 欧美视频在线视频| 先锋资源久久| 欧美一区二区三区精品电影| 国产一区二区视频在线观看| 久久婷婷国产综合国色天香| 欧美专区日韩视频| 在线日韩欧美| 91久久精品一区二区三区| 欧美日韩精品二区| 亚洲一区三区视频在线观看| 亚洲欧美激情视频在线观看一区二区三区| 国产精品久久久久aaaa樱花| 久久精品二区| 六月丁香综合| 亚洲图片在线| 欧美一区二区三区在线视频| 伊伊综合在线| 亚洲美女在线国产| 国产啪精品视频| 欧美成人四级电影| 欧美日韩一区二区在线视频| 欧美一区免费视频| 久久影院午夜片一区| 99精品免费| 亚洲欧美在线磁力| 91久久午夜| 亚洲女女女同性video| 亚洲激情国产精品| 亚洲在线视频一区| 亚洲精品四区| 午夜久久一区| 一本一本久久| 久久久精品国产免费观看同学| 99re6这里只有精品视频在线观看| 亚洲视屏一区| 亚洲欧洲在线观看| 新狼窝色av性久久久久久| 亚洲国产一区二区三区青草影视| 中文精品视频一区二区在线观看| 激情久久婷婷| 亚洲欧美视频在线| 在线午夜精品自拍| 美女福利精品视频| 欧美一级午夜免费电影| 欧美精选一区| 欧美a级片网站| 国产日韩精品一区| 正在播放亚洲一区| 一区二区三区高清不卡| 久久只有精品| 久久婷婷综合激情| 国产欧美日韩麻豆91| 亚洲一区二区三区乱码aⅴ蜜桃女| 美女脱光内衣内裤视频久久网站| 国产精品乱码妇女bbbb| 亚洲国产精品va在线看黑人 | 久久精品国产99精品国产亚洲性色 | 久久精品国产免费观看| 欧美人与性动交cc0o| 欧美国产亚洲精品久久久8v| 国产一区二区三区成人欧美日韩在线观看| 亚洲精品国产视频| 99精品国产一区二区青青牛奶| 欧美88av| 欧美激情91| 亚洲国产欧美在线| 免费成人在线观看视频| 欧美11—12娇小xxxx| 亚洲第一精品福利| 免播放器亚洲一区| 亚洲国产小视频在线观看| 亚洲欧洲日产国产综合网| 欧美va天堂| 亚洲美女在线看| 午夜激情久久久| 国产日韩欧美不卡| 欧美中文在线观看国产| 久久看片网站| 亚洲欧洲精品一区二区| 欧美国产先锋| 一本一本久久a久久精品牛牛影视| 亚洲一品av免费观看| 国产精品亚洲综合久久| 欧美一区二区三区在线看| 久久亚洲精品伦理| 亚洲人精品午夜在线观看| 欧美日韩国产黄| 亚洲一区二区av电影| 久久久国产精品亚洲一区| 在线日韩中文| 欧美日韩免费网站| 午夜精品久久久久久久久久久久| 久久久久久9| 亚洲免费观看| 国产精品影院在线观看| 开元免费观看欧美电视剧网站| 亚洲电影免费观看高清完整版在线 | 亚洲国产精品久久| 亚洲性图久久| 一区二区自拍| 欧美色播在线播放| 久久精品理论片| 99热在这里有精品免费| 久久久久久久国产| 99国内精品久久| 国内成+人亚洲| 欧美日韩国产影院| 久久久久久久波多野高潮日日| 亚洲精品午夜精品| 久久综合激情| 亚洲欧美综合| 亚洲精品国产精品乱码不99 | 欧美性感一类影片在线播放| 国产精品久久久久一区| 久久精品一区二区三区不卡牛牛| 亚洲国内精品| 久久久午夜视频| 亚洲一区制服诱惑| 亚洲激情影院| 韩国三级在线一区| 国产精品欧美日韩一区| 欧美激情黄色片| 久久全国免费视频| 欧美一级在线播放| 一区二区三区产品免费精品久久75 | 久久久www免费人成黑人精品| 一本色道久久综合| 1024成人网色www| 国产视频精品网| 国产精品国产一区二区| 欧美精品久久久久久| 免费国产自线拍一欧美视频| 久久精品久久99精品久久|