• <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>

            Life is Good.

            Enhance Tech and English
            隨筆 - 65, 文章 - 20, 評論 - 21, 引用 - 0
            數據加載中……

            單線鏈表常見操作

            1.單線鏈表倒序/逆序:
            struct Node
            {
                int data;
                Node* next;
            };

            Node* Reverse(Node* head)
            {
                struct Node *prep,*nowp,*nextp;

                prep=NULL;
                nowp=head;

                while(nowp!=NULL)
                {
                    nextp=nowp->next;
                    nowp->next=prep;
                    prep=nowp;
                    nowp=nextp;
                }

                return prep;
            }

            2. 判斷單向鏈表是否有環。下圖的三種情形都視為有環,算法必須能處理它們。


            01) 如果知道鏈表長度, 則可以遍歷鏈表, 遍歷次數大于長度, 就是有環了

               int iLength; 鏈表長度, 已知
               int i = 0;
               while (p != NULL)
               {
                   i ++;
                   if (i > iLength)
                   {
                       break;
                       return;
                   }
               }

            02)解法:設置兩個指針,一個每次向前跳一步,一個跳兩步,如果它們相遇,則有環。


            bool fLinkedListHasCircle(const Node* p)
            {
             bool flag = false;
             
             const Node* slowIterator = p;
             const Node* fastIterator = p;

             while(slowIterator && fastIterator->next)
             {
              slowIterator = slowIterator->next;
              fastIterator = fastIterator->next->next;
              if (slowIterator == fastIterator)
              {
               flag = true;
               break;
              }
             }
             return flag;
            }

            快速證明算法的正確性:

            考慮一般的情形,假設環上有n個結點,把它們從0到n-1編號,假設slowIterator達到節點0時,fastIterator領先 slowIterator的距離為m,我們知道fastIterator在一圈之內必能追上slowIterator。假設x跳以后 fastIterator追上slowIterator,此時slowIterator所在的結點編號為x,而fastIterator所在的節點編號為 m+2x-n:

            x = m+2x-n
            x = n-m

            所以經過n-m跳后,fastIterator追上slowIterator。


            posted on 2010-10-19 16:26 Mike Song 閱讀(248) 評論(0)  編輯 收藏 引用

            久久婷婷人人澡人人爽人人爱| av国内精品久久久久影院| 久久成人国产精品| 日韩亚洲欧美久久久www综合网 | 久久人人超碰精品CAOPOREN| 一级做a爰片久久毛片毛片| AV狠狠色丁香婷婷综合久久| 88久久精品无码一区二区毛片| 久久精品国产精品亚洲精品| 国产V综合V亚洲欧美久久| 色播久久人人爽人人爽人人片aV| 久久九九精品99国产精品| 99久久国产综合精品成人影院| 日本WV一本一道久久香蕉| 精品国产青草久久久久福利| 久久99精品国产麻豆| 久久精品无码免费不卡| 国产精品美女久久久久av爽| 99久久婷婷国产综合亚洲| 欧美久久亚洲精品| 国产日韩久久免费影院| WWW婷婷AV久久久影片| 囯产极品美女高潮无套久久久| 久久亚洲国产成人精品无码区| 国产成人久久精品激情| 久久精品国产亚洲αv忘忧草 | 日韩精品久久久久久久电影蜜臀| 欧美成人免费观看久久| 久久这里只有精品视频99| 久久精品国产99国产精品澳门 | 国产成人精品久久一区二区三区av | 波多野结衣中文字幕久久| 久久久久亚洲AV无码麻豆| 久久久久se色偷偷亚洲精品av| 亚洲欧美日韩精品久久亚洲区 | 久久精品国产亚洲麻豆| 无码精品久久久久久人妻中字| 久久精品麻豆日日躁夜夜躁| 18禁黄久久久AAA片| 国色天香久久久久久久小说| 一本一本久久aa综合精品|