• <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>
            隨筆-159  評論-223  文章-30  trackbacks-0
               原題為某游戲公司試題,大意如下:  對于一個單向鏈表,試寫出找到它的倒序第m個元素(m >= 1)的函數,注意變量命名、注釋、時間復雜度、空間復雜度。注:要求寫出可編譯并可以運行通過的程序代碼。

              這道題的常規做法或者說首先想到直覺的方法M1是先求得鏈表的長度,即元素總個數n,然后問題轉化為求順序第n-m+1個元素。下面給出第2種方法M2:先求得順序第m個元素,用一指針P指向這個元素,用另一指針PR指向鏈表的頭部,現在好了,P和PR同時向右移動,直到P為空,則PR就是要求的倒序第m個元素,如果因m超越界限,則PR為空,表示沒找到,這樣一來,只需一次循環就夠了。C++代碼描述如下
             1 template<typename T>
             2 struct Node
             3 {  
             4     T  data;    /**////< 數據
             5     Node* next;  ///< 指向下一結點的指針
             6 } ;

             7 
             8 template<typename T>
             9 Node<T>* ReverseFind(Node<T>* head, size_t m)
            10{
            11    size_t  n = 0;
            12    Node<T> *p, *pR = NULL;
            13    for (p = head;p;p = p->next)
            14    {
            15        if (++== m)
            16        {
            17            pR = head;
            18            continue;
            19        }

            20        if (pR)
            21        {
            22            pR = pR->next;
            23        }

            24    }

            25    return pR;
            26}
              現在分析這2種方法的時間復雜度,假設鏈表元素個數為N,所求倒序為第M元素,N>=M,則M1方法為0(N)+0(N-M)=0(2N-M),M2方法為O(M)+O(N-M)=0(N),因此M2快于M1。
            posted on 2011-06-24 11:40 春秋十二月 閱讀(2538) 評論(11)  編輯 收藏 引用 所屬分類: Algorithm

            評論:
            # re: 求單向鏈表倒序第m個元素 2011-06-24 12:30 | coreBugZJ
            贊一個  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-06-24 16:45 | paw
            額,,考研數據結構題。。。  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-06-24 23:57 | 魚吃貓
            頂一個~  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素[未登錄] 2011-06-25 12:06 | 英雄哪里出來
            不錯,贊一個~~  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素[未登錄] 2011-06-25 13:39 | kaka
            第一個指針從頭移動到m,和第二個指針一起再移動到尾部。

            第二個指針和第一個指針一起移動。

            只不過將一個指針大于一次遍歷的操作分解成兩個指針操作。

            這樣算是一次遍歷?  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-06-25 23:36 | 夢提
            是一次遍歷,因為時間上是同步的。@kaka
              回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-06-26 08:47 | 搞笑
            這個也太搞笑了?效率是一樣的,還竟然有:“這樣效率不高”的說法。  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-06-26 13:54 | temp
            是一樣的,兩個指針分別遍歷。  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-06-26 15:24 | Arcko
            貌似需要遍歷的確實是一樣的多,不過換個思路考慮也很好  回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-06-27 10:09 | megadeath
            使用遞歸方式(示例代碼,無任何錯誤檢查),把for語句也消隱掉。

            static int nOrder = 0;
            template <typename ITERATOR, typename UINT>
            void F(ITERATOR begin, ITERATOR end, UINT M)
            {
            ITERATOR it = begin;
            if (begin != end)
            F(++begin, end, M);

            if (++nOrder == ++M)
            cout << *it << endl;
            }
              回復  更多評論
              
            # re: 求單向鏈表倒序第m個元素 2011-07-01 11:06 | 有霧
            我也感覺效率一樣的。第二個里面,同樣要把P移動到鏈表尾,這樣才能獲得size。所以不存在O(M),同樣是O(N)啊。@搞笑
              回復  更多評論
              
            久久男人中文字幕资源站| 久久婷婷五月综合色高清| 久久www免费人成精品香蕉| 久久久精品国产亚洲成人满18免费网站 | 青草久久久国产线免观| 漂亮人妻被中出中文字幕久久 | AV狠狠色丁香婷婷综合久久| 99久久久国产精品免费无卡顿| 品成人欧美大片久久国产欧美| 麻豆精品久久久久久久99蜜桃| 狠狠色丁香久久婷婷综合五月| 国产精品午夜久久| 国产美女久久精品香蕉69| 久久婷婷五月综合色99啪ak| 久久成人国产精品| 久久露脸国产精品| 97精品国产91久久久久久| 亚洲精品97久久中文字幕无码| 热久久这里只有精品| 97久久国产露脸精品国产| 久久国产精品免费一区二区三区| 99精品久久久久久久婷婷| 婷婷久久综合| 久久久久国产精品嫩草影院| 亚洲国产精久久久久久久| 久久亚洲精品中文字幕| 思思久久精品在热线热| 少妇熟女久久综合网色欲| 日韩欧美亚洲综合久久影院Ds| 欧美亚洲国产精品久久蜜芽| 久久精品国内一区二区三区| AV无码久久久久不卡蜜桃| 国产精品久久久久jk制服| 99久久国产精品免费一区二区| 久久精品无码一区二区WWW| 亚洲日本va午夜中文字幕久久 | 久久国产精品偷99| 四虎国产精品成人免费久久| 久久影视综合亚洲| 久久天天躁狠狠躁夜夜不卡 | 国产精品女同久久久久电影院|