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

      那誰的技術博客

      感興趣領域:高性能服務器編程,存儲,算法,Linux內核
      隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
      數據加載中……

      另類的鏈表數據結構以及算法

      一般情況下,我們使用鏈表無非就是在鏈表結點中保存該鏈表中下一個元素的指針.如果為了刪除方便,可能需要保存前一個元素的指針,也就是雙向鏈表,這樣在刪除一個結點的時候就可以很快的定位到前面和后面的結點,并且改變它們相應的指向.在這些操作里面,指向鏈表元素的指針無疑是最關鍵的數據.

      考慮這樣一個問題,如果兩個進程進行通信,A進程負責管理鏈表,B進程向A進程發出分配或者刪除鏈表元素的請求.這種情況下,像上面所描述的那樣A進程直接向B進程返回鏈表元素的指針是不能做到的了,很自然的,可以想到返回另一個key標示該鏈表元素.但是,當需要查找或者刪除該鏈表元素的時候,就不能像上面那樣馬上定位到鏈表元素的位置了,需要遍歷整個鏈表.原來常量級時間復雜度的算法,在使用情形變換了之后變成了O(n)級別的復雜度.

      可以找到別的辦法來解決這個問題.第一可以返回一個key標示該鏈表元素,第二保證了時間的復雜度,在這里需要定義一種新的數據結構和算法來解決這個問題.

      首先,我們使用一個數組,數組中的元素是指向鏈表元素的指針,而指針的索引則是每個鏈表元素的id,這樣,通過id就可以馬上定位到對應的鏈表元素.
      但是這里又會出現另一個問題,該id是從零開始的,假如在一段時間之后,需要分配一個新的鏈表元素,如何知道數組中的哪個位置是可以分配的?在這里,使用了一個整型數據的數組,數組中的每個元素是該id對應的鏈表元素在鏈表中下一個結點的id(有點拗口).我們使用兩個鏈表頭,一個將已經使用的鏈表元素id連接起來,另一個則將未使用的鏈表元素id連接起來.于是,在程序初始化的時候,未使用的鏈表中保存了所有的id,而已經使用的鏈表為空.每次分配了一個新的鏈表元素,將它的id放在使用鏈表的最開始;而每次釋放一個鏈表元素,將它的id放到未使用的鏈表頭部.
      同時,改變原先鏈表元素的定義,在該結構體中,保存的不再是指針,而是鏈表中前一個元素的數組索引id.而它的下一個元素id則保存在上面的那個數組中.

      如果上面我的解釋還不夠明白,可以看看下面的代碼:

      #include 
      <stdio.h>

      #define LIST_NODE_NULL -1
      #define ARRAY_SIZE 200

      /* 鏈表元素定義 */
      typedef 
      struct list_node
      {
          
      int prev;   /* 下一個鏈表元素在list_array中的id */
      }list_node;

      /* 存放鏈表元素指針的數組 */
      list_node
      * list_array[ARRAY_SIZE];
      /* 未使用鏈表的頭結點id */
      int top_of_free;
      /* 已使用鏈表的頭結點id */
      int top_of_used;
      /* 保存鏈表下一個元素結點id的鏈表 */
      int next_list[ARRAY_SIZE];

      void init_list()
      {
          
      int i;

          
      for (i = 0; i < ARRAY_SIZE; ++i)
          {
              list_array[i] 
      = NULL;
              
      /* 初始時,next_list中每個結點的值都是下一個id */
              next_list[i] 
      = i + 1;
          }

          
      /* 最后一個結點是空 */
          next_list[i 
      - 1= LIST_NODE_NULL;

          top_of_free 
      = 0;
          top_of_used 
      = LIST_NODE_NULL;
      }

      int alloc_list_node()
      {
          
      int id;
          
          
      /* 從未使用鏈表頭部取出一個id */
          id 
      = top_of_free;

          
      if (LIST_NODE_NULL == id)
          {
              
      return LIST_NODE_NULL;
          }

          
      /* 未使用鏈表頭結點往下走一步 */
          top_of_free 
      = next_list[top_of_free];

          
      if (NULL == list_array[id])
          {
              list_array[id] 
      = (list_node*)malloc(sizeof(list_node));
              
      if (NULL == list_array[id])
              {
                  
      return LIST_NODE_NULL;
              }
          }

          
      if (LIST_NODE_NULL == top_of_used)
          {
             
      next_list[id] = top_of_used; 
              top_of_used = id;

          }
          
      else
          {
              
      /* 修改prev和next */ 
              list_array[top_of_used]
      ->prev = id;
              list_array[id]
      ->prev = LIST_NODE_NULL;

              next_list[id] 
      = top_of_used;
              top_of_used 
      = id;
          }

          
      return id;
      }

      void free_list_node(int id)
      {
          
      int prev, next;

          prev 
      = list_array[id]->prev;
          next 
      = next_list[id];

          
      /* 修改next和prev */
          if (
      LIST_NODE_NULL != prev)
          {
              next_list[prev] 
      = next_list[id];
          }
          
      if (LIST_NODE_NULL != next && NULL != list_array[next])
          {
              list_array[next]
      ->prev = prev;
          }

          
      if (id == top_of_used)
          {
              top_of_used 
      = next_list[id];
          }

          
      /* 將鏈表id返回到free鏈表頭部并且修改free鏈表頭結點 */
          next_list[id] 
      = top_of_free;
          top_of_free 
      = id;
      }

      int main()
      {
          
      int id;

          init_list();

          id 
      = alloc_list_node();
          free_list_node(id);

          
      return 0;
      }



      這個想法很巧妙,有效的避免了查找和刪除數組元素帶來的開銷.我不知道具體的出處在哪里,如果您知道,勞煩告訴我一聲:)


      posted on 2009-03-22 19:14 那誰 閱讀(4535) 評論(7)  編輯 收藏 引用 所屬分類: 算法與數據結構

      評論

      # re: 另類的鏈表數據結構以及算法  回復  更多評論   

      如果我沒理解錯誤的話:
      1 這個應該是靜態鏈表的變形。
      2 示例程序似乎有些地方有問題.
      (1)分配算法里邊的:
      if (LIST_NODE_NULL == top_of_used)
      {
      top_of_used = id;
      }
      是否應該改為:
      if (LIST_NODE_NULL == top_of_used)
      {
      next_list[id] = top_of_used;
      top_of_used = id;

      }
      (2)釋放函數:
      next_list[prev] = next_list[next_list[id]];
      if (NULL != list_array[next])
      {
      list_array[next]->prev = prev;
      }
      next_list[prev]和list_array[next]都有可能造成數組越界。

      另外,這個next_list[prev] = next_list[next_list[id]];是否應該改為
      next_list[prev] = next_list[id]?
      2009-03-27 13:31 | capable

      # re: 另類的鏈表數據結構以及算法  回復  更多評論   

      感謝指出錯誤,已經做了修改了.
      2009-03-27 19:03 | 那誰

      # re: 另類的鏈表數據結構以及算法  回復  更多評論   

      別客氣,應該的。
      從你的博客,我學到了不少東西,希望能夠在這里看到更多你的大作。
      2009-03-27 22:14 | capable

      # re: 另類的鏈表數據結構以及算法  回復  更多評論   

      為什么不直接使用鏈表節點指針作為key呢?
      2009-03-28 15:22 | t

      # re: 另類的鏈表數據結構以及算法  回復  更多評論   

      應該是 Justin Heyes-Jones 在 A* Algorithm code 中的 fast simple allocator 使用的結構
      http://code.google.com/p/a-star-algorithm-implementation/downloads/list
      2009-04-11 01:48 | alan5281

      # re: 另類的鏈表數據結構以及算法  回復  更多評論   

      申請新結點空間后,應該初始化結點,否則釋放時會出現問題。
      list_array[identity] = new list_node;
      if(NULL == list_array[identity])
      {
      return(list_node_null);
      }
      list_array[identity]->prev = list_node_null;
      2009-06-03 08:59 | zuima

      # re: 另類的鏈表數據結構以及算法  回復  更多評論   

      算法導論10.3介紹了這種用法,包括后面提到的用兩個鏈表來維護用過的和為用過的節點
      2010-08-22 02:00 | Dbger
      青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
    1. <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>
              日韩视频一区| 欧美亚男人的天堂| 性色av一区二区三区在线观看 | 久久激情视频| 亚洲激情黄色| 国产午夜精品一区二区三区欧美 | 亚洲精品女av网站| 日韩视频不卡中文| 亚洲精品欧洲| 亚洲精品国产无天堂网2021| 精品二区视频| 精品成人一区二区三区| 国内精品久久久久久久影视蜜臀| 国产精品久久久久一区二区三区| 欧美日韩国产不卡| 国产精品嫩草影院av蜜臀| 欧美国产精品劲爆| 亚洲黄一区二区三区| 亚洲精品视频免费| 亚洲无毛电影| 久久琪琪电影院| 欧美精品在线播放| 国产亚洲成av人在线观看导航| 国产欧美视频一区二区三区| 国产一区二区三区无遮挡| 国产视频在线一区二区| 美女精品网站| 国产精品久99| 欧美激情第8页| 99国产精品| 欧美大片免费观看| 国产裸体写真av一区二区| 精品不卡在线| 羞羞漫画18久久大片| 亚洲国产精品一区在线观看不卡| 日韩视频免费看| 久久久噜噜噜久噜久久 | 黄色成人片子| 亚洲精品视频免费观看| 久久九九久久九九| 欧美中文字幕视频在线观看| 欧美日韩视频在线一区二区| 亚洲精品一区二区三区福利| 久久综合九九| 老司机精品视频一区二区三区| 欧美.www| 午夜在线a亚洲v天堂网2018| 国产精品成人久久久久| 一本色道久久综合亚洲二区三区| 欧美国产视频日韩| 免费影视亚洲| 亚洲一二区在线| 亚洲永久在线| 国产一区二区福利| 久久综合九色欧美综合狠狠| 午夜视频在线观看一区二区三区| 欧美午夜久久久| 欧美一区二区三区四区在线| 欧美中文字幕在线播放| 在线观看视频欧美| 99成人精品| 在线观看国产日韩| 一本色道**综合亚洲精品蜜桃冫| 欧美日韩免费高清一区色橹橹| 亚洲欧美日韩中文视频| 久久9热精品视频| 亚洲日本乱码在线观看| 亚洲欧美欧美一区二区三区| 国产日韩欧美不卡| 日韩一级大片| 日韩亚洲欧美综合| 亚洲看片网站| 欧美中文字幕在线| 一区二区日韩欧美| 免费日韩视频| 欧美激情亚洲精品| 激情91久久| 欧美一级二区| 欧美在线观看日本一区| 欧美精品一区二区久久婷婷| 久久资源av| 亚洲免费精彩视频| 99在线精品视频在线观看| 欧美国产精品| 欧美激情一区二区久久久| 亚洲人久久久| 一区二区三区视频在线| 国产欧美一区二区色老头| 久久久青草青青国产亚洲免观| 麻豆精品传媒视频| 亚洲一级高清| 久久久av毛片精品| 夜夜躁日日躁狠狠久久88av| 香蕉久久夜色精品国产| 精品成人一区| 99在线|亚洲一区二区| 国产一区免费视频| 亚洲日本欧美| 亚洲一区免费视频| 久久久久一区二区| 亚洲手机成人高清视频| 久久gogo国模啪啪人体图| 在线亚洲高清视频| 久久这里只有| 久久国产精品一区二区| 欧美精品在线观看91| 久久久99国产精品免费| 欧美日韩国产bt| 鲁鲁狠狠狠7777一区二区| 国产精品豆花视频| 亚洲国产精品一区二区第一页| 国产精品亚洲激情| 日韩亚洲不卡在线| 亚洲第一在线| 香蕉成人伊视频在线观看| 亚洲天堂偷拍| 欧美电影美腿模特1979在线看| 久久成人亚洲| 欧美涩涩网站| 日韩午夜在线播放| 9l视频自拍蝌蚪9l视频成人| 久久一区欧美| 欧美成人日韩| 国产一区二区丝袜高跟鞋图片| 日韩五码在线| 夜久久久久久| 欧美成人xxx| 欧美丰满少妇xxxbbb| 在线播放中文字幕一区| 欧美一级精品大片| 欧美在线视频导航| 国产麻豆精品久久一二三| 日韩亚洲精品在线| 亚洲美女精品久久| 欧美不卡高清| 亚洲国产精品久久久久| 亚洲激情视频在线观看| 久热精品视频在线观看| 蜜臀久久久99精品久久久久久| 好看不卡的中文字幕| 久久精品国产一区二区三区 | 久久精品国产96久久久香蕉| 国产精品久久精品日日| 亚洲视频电影在线| 欧美一区二区三区四区视频| 国产欧美日韩视频在线观看 | 亚洲黄色片网站| 亚洲深夜福利在线| 性色av香蕉一区二区| 国产伦理精品不卡| 久久精品国产亚洲一区二区| 久久久久久久激情视频| 影音先锋一区| 欧美承认网站| 亚洲精品日韩在线观看| 亚洲欧美制服另类日韩| 国产性做久久久久久| 免费在线观看精品| 日韩视频在线你懂得| 亚洲综合色视频| 国产日韩一区欧美| 麻豆久久婷婷| 一级日韩一区在线观看| 久久精品国产第一区二区三区| 在线观看视频一区| 欧美日韩免费一区| 亚洲欧美视频在线| 模特精品在线| 亚洲午夜视频| 一区二区三区在线观看欧美| 欧美精品激情blacked18| 亚洲欧美日本国产专区一区| 欧美成人免费全部观看天天性色| 一区二区欧美日韩| 国产亚洲精品久久久久久| 欧美成人免费网| 亚洲欧美日韩一区二区在线 | 噜噜噜噜噜久久久久久91| 日韩一区二区精品葵司在线| 国产欧美日韩在线 | 亚洲一区三区视频在线观看| 久久婷婷人人澡人人喊人人爽| 亚洲人成7777| 国产亚洲人成a一在线v站 | 午夜精品福利一区二区蜜股av| 影音先锋国产精品| 国产精品日韩精品| 欧美jizzhd精品欧美巨大免费| 亚洲伊人第一页| 亚洲经典三级| 另类专区欧美制服同性| 香蕉亚洲视频| 日韩一二在线观看| 极品中文字幕一区| 国产伦精品一区| 欧美日韩高清在线观看| 久久影视精品| 久久久www成人免费无遮挡大片 | 久久午夜精品| 亚洲女人天堂av|