亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? algo8-1.cpp

?? 數據結構(嚴慰民)配套純C代碼,準確理解源代碼的真諦
?? CPP
字號:
 // algo8-1.cpp 邊界標識法。實現算法8.1的程序
 #include"c1.h"
 #include"c8-1.h"
 #define MAX 1000 // 可利用空間的大小(以WORD的字節數為單位)
 #define e 10 // 塊的最小尺寸-1(以WORD的字節數為單位)

 Space AllocBoundTag(Space &pav,int n) // 算法8.1(首次擬合法)
 { // 若有不小于n的空閑塊,則分配相應的存儲塊,并返回其首地址;否則返回NULL
   // 若分配后可利用空間表不空,則pav指向表中剛分配過的結點的后繼結點
   Space p,f;
   for(p=pav;p&&p->size<n&&p->rlink!=pav;p=p->rlink); // 查找不小于n的空閑塊
   if(!p||p->size<n) // 找不到,返回空指針
     return NULL;
   else // p指向找到的空閑塊
   {
     f=FootLoc(p); // 指向底部
     pav=p->rlink; // pav指向*p結點的后繼結點
     if(p->size-n<=e) // 整塊分配,不保留<=e的剩余量
     {
       if(pav==p) // 可利用空間表變為空表
         pav=NULL;
       else // 在表中刪除分配的結點
       {
         pav->llink=p->llink;
         p->llink->rlink=pav;
       }
       p->tag=f->tag=1; // 修改分配結點的頭部和底部標志
     }
     else // 分配該塊的后n個字(高地址部分)
     {
       f->tag=1; // 修改分配塊的底部標志
       p->size-=n; // 置剩余塊大小
       f=FootLoc(p); // 指向剩余塊底部
       f->tag=0; // 設置剩余塊底部
       f->uplink=p;
       p=f+1; // 指向分配塊頭部
       p->tag=1; // 設置分配塊頭部
       p->size=n;
     }
     return p; // 返回分配塊首地址
   }
 }

 void Reclaim(Space &pav,Space &p)
 { // 邊界標識法的回收算法
   Space s=(p-1)->uplink,t=p+p->size; // s、t分別指向釋放塊的左、右鄰塊(空閑時)的首地址
   int l=(p-1)->tag,r=(p+p->size)->tag; // l、r分別指示釋放塊的左、右鄰塊是否空閑
   if(!pav) // 可利用空間表空
   { // 將釋放塊加入到pav所指的可利用空間表中
     pav=p->llink=p->rlink=p; // 頭部域的兩個指針及pav均指向釋放塊
     p->tag=0; // 修改頭部域塊標志為空閑
     (FootLoc(p))->uplink=p; // 修改尾部域
     (FootLoc(p))->tag=0;
   }
   else // 可利用空間表不空
   {
     if(l==1&&r==1) // 左右鄰區均為占用塊
     {
       p->tag=0; // 修改頭部域塊標志為空閑
       (FootLoc(p))->uplink=p; // 修改尾部域
       (FootLoc(p))->tag=0;
       pav->llink->rlink=p; // 將p所指結點(剛釋放的結點)插在pav所指結點之前
       p->llink=pav->llink;
       p->rlink=pav;
       pav->llink=p;
       pav=p; // 修改pav,令剛釋放的結點為下次分配時的最先查詢的結點
     }
     else if(l==0&&r==1) // 左鄰區為空閑塊,右鄰區為占用塊
     { // 合并左鄰塊和釋放塊
       s=(p-1)->uplink; // 左鄰空閑塊的頭部地址
       s->size+=p->size; // 設置新的空閑塊大小
       t=FootLoc(p); // 設置新的空閑塊底部
       t->uplink=s;
       t->tag=0;
     }
     else if(l==1&&r==0) // 右鄰區為空閑塊,左鄰區為占用塊
     { // 合并右鄰塊和釋放塊
       p->tag=0; // P為合并后的結點頭部地址
       p->llink=t->llink; // p的前驅為原t的前驅
       p->llink->rlink=p; // p的前驅的后繼為p
       p->rlink=t->rlink; // p的后繼為原t的后繼
       p->rlink->llink=p; // p的后繼的前驅為p
       p->size+=t->size; // 新的空閑塊的大小
       (FootLoc(t))->uplink=p; // 底部(原t的底部)指針指向新結點的頭部
       if(pav==t) // 可利用空間表的頭指針指向t(t已不是空閑結點首地址了)
         pav=p; // 修改pav,令剛釋放的結點為下次分配時的最先查詢的結點
     }
     else // 左右鄰區均為空閑塊
     {
       s->size+=p->size+t->size; // 設置新結點的大小
       t->llink->rlink=t->rlink; // 刪去右鄰空閑塊結點
       t->rlink->llink=t->llink;
       (FootLoc(t))->uplink=s; // 新結點底部(原t的底部)指針指向其頭部
       if(pav==t) // 可利用空間表的頭指針指向t(t已不是空閑結點首地址了)
         pav=s; // 修改pav,令剛釋放的結點為下次分配時的最先查詢的結點
     }
   }
   p=NULL; // 令剛釋放的結點的指針為空
 }

 void Print(Space p)
 { // 輸出p所指的可利用空間表
   Space h,f;
   if(p) // 可利用空間表不空
   {
     h=p; // h指向第一個結點的頭部域(首地址)
     f=FootLoc(h); // f指向第一個結點的底部域
     do
     {
       printf("塊的大小=%d 塊的首地址=%u ",h->size,f->uplink); // 輸出結點信息
       printf("塊標志=%d(0:空閑 1:占用) 鄰塊首地址=%u\n",h->tag,f+1);
       h=h->rlink; // 指向下一個結點的頭部域(首地址)
       f=FootLoc(h); // f指向下一個結點的底部域
     }while(h!=p); // 沒到循環鏈表的表尾
   }
 }

 void PrintUser(Space p[])
 { // 輸出p數組所指的已分配空間
   for(int i=0;i<MAX/e;i++)
     if(p[i]) // 指針不為0(指向一個占用塊)
     {
       printf("塊%d的首地址=%u ",i,p[i]); // 輸出結點信息
       printf("塊的大小=%d 塊頭標志=%d(0:空閑 1:占用)",p[i]->size,p[i]->tag);
       printf(" 塊尾標志=%d\n",(FootLoc(p[i]))->tag);
     }
 }

 void main()
 {
   Space pav,p; // 空閑塊指針
   Space v[MAX/e]={NULL}; // 占用塊指針數組(初始化為空)
   int n;
   printf("結構體WORD為%d個字節\n",sizeof(WORD));
   p=new WORD[MAX+2]; // 申請大小為MAX*sizeof(WORD)個字節的空間
   p->tag=1; // 設置低址邊界,以防查找左右鄰塊時出錯
   pav=p+1; // 可利用空間表的表頭
   pav->rlink=pav->llink=pav; // 初始化可利用空間(一個整塊)
   pav->tag=0;
   pav->size=MAX;
   p=FootLoc(pav); // p指向底部域
   p->uplink=pav;
   p->tag=0;
   (p+1)->tag=1; // 設置高址邊界,以防查找左右鄰塊時出錯
   printf("初始化后,可利用空間表為:\n");
   Print(pav);
   n=300;
   v[0]=AllocBoundTag(pav,n);
   printf("分配%u個存儲空間后,可利用空間表為:\n",n);
   Print(pav);
   PrintUser(v);
   n=450;
   v[1]=AllocBoundTag(pav,n);
   printf("分配%u個存儲空間后,pav為:\n",n);
   Print(pav);
   PrintUser(v);
   n=300; // 分配不成功
   v[2]=AllocBoundTag(pav,n);
   printf("分配%u個存儲空間后(不成功),pav為:\n",n);
   Print(pav);
   PrintUser(v);
   n=242; // 分配整個塊(250)
   v[2]=AllocBoundTag(pav,n);
   printf("分配%u個存儲空間后(整塊分配),pav為:\n",n);
   Print(pav);
   PrintUser(v);
   printf("回收v[0](%d)后(當pav空時回收),pav為:\n",v[0]->size);
   Reclaim(pav,v[0]); // pav為空
   Print(pav);
   PrintUser(v);
   printf("1按回車鍵繼續");
   getchar();
   printf("回收v[2](%d)后(左右鄰區均為占用塊),pav為:\n",v[2]->size);
   Reclaim(pav,v[2]); // 左右鄰區均為占用塊
   Print(pav);
   PrintUser(v);
   n=270; // 查找空間足夠大的塊
   v[0]=AllocBoundTag(pav,n);
   printf("分配%u個存儲空間后(查找空間足夠大的塊),pav為:\n",n);
   Print(pav);
   PrintUser(v);
   n=30; // 在當前塊上分配
   v[2]=AllocBoundTag(pav,n);
   printf("分配%u個存儲空間后(在當前塊上分配),pav為:\n",n);
   Print(pav);
   PrintUser(v);
   printf("回收v[1](%d)后(右鄰區為空閑塊,左鄰區為占用塊),pav為:\n",v[1]->size);
   Reclaim(pav,v[1]); // 右鄰區為空閑塊,左鄰區為占用塊
   Print(pav);
   PrintUser(v);
   printf("2按回車鍵繼續");
   getchar();
   printf("回收v[0](%d)后(左鄰區為空閑塊,右鄰區為占用塊),pav為:\n",v[0]->size);
   Reclaim(pav,v[0]); // 左鄰區為空閑塊,右鄰區為占用塊
   Print(pav);
   PrintUser(v);
   printf("回收v[2](%d)后(左右鄰區均為空閑塊),pav為:\n",v[2]->size);
   Reclaim(pav,v[2]); // 左右鄰區均為空閑塊
   Print(pav);
   PrintUser(v);
 }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91免费版在线看| 久久97超碰国产精品超碰| av在线一区二区三区| 欧美国产综合色视频| 北条麻妃一区二区三区| 亚洲男人的天堂一区二区| 91老师国产黑色丝袜在线| 亚洲理论在线观看| 欧美日韩1234| 久草在线在线精品观看| 欧美极品xxx| 色偷偷88欧美精品久久久| 亚洲成人一区在线| 日韩欧美一级二级三级| 国产成人午夜视频| 亚洲激情自拍偷拍| 日韩区在线观看| 国产aⅴ综合色| 亚洲国产日韩av| 2024国产精品| 色综合久久久久久久久| 亚洲成人av福利| 久久蜜桃av一区精品变态类天堂 | 91精品一区二区三区在线观看| 图片区日韩欧美亚洲| 欧美成人猛片aaaaaaa| 99国产麻豆精品| 蜜臀av国产精品久久久久 | 精品理论电影在线观看| 99久久精品国产一区二区三区 | 欧美电视剧在线观看完整版| 国产成人精品亚洲777人妖| 极品瑜伽女神91| 亚洲乱码中文字幕综合| 精品久久久网站| 色欧美日韩亚洲| 国产电影精品久久禁18| 图片区小说区国产精品视频| 国产精品传媒在线| 日韩欧美国产系列| 91国偷自产一区二区三区成为亚洲经典| 欧美日韩一二三| 国产成人在线网站| 日韩成人伦理电影在线观看| 亚洲欧洲av另类| 精品欧美乱码久久久久久1区2区| 91国偷自产一区二区开放时间| 国产揄拍国内精品对白| 丝袜诱惑亚洲看片| 亚洲欧美日韩小说| 中文字幕av一区二区三区| 日韩美女视频在线| 欧美日韩一区在线观看| 99精品视频在线观看免费| 精品在线播放免费| 日韩精品乱码av一区二区| 亚洲综合免费观看高清完整版在线 | 亚洲免费在线观看| 久久久亚洲精品一区二区三区| 在线不卡免费av| 欧美午夜免费电影| 在线中文字幕一区二区| 97se亚洲国产综合自在线| 国产91在线观看| 国产aⅴ综合色| 国产风韵犹存在线视精品| 韩国欧美国产1区| 久久精品理论片| 久久不见久久见免费视频1| 免费在线成人网| 日本视频中文字幕一区二区三区| 亚洲一区二区三区国产| 一区二区三区精品视频| 亚洲激情在线激情| 亚洲精品日韩综合观看成人91| 国产精品毛片高清在线完整版| 国产三级精品视频| 国产午夜一区二区三区| 久久精品欧美一区二区三区麻豆| 精品国产一区二区三区不卡 | 久久九九全国免费| 国产欧美精品一区二区三区四区 | 精品一区在线看| 欧美性猛片xxxx免费看久爱| 91精品1区2区| 欧美三级中文字幕在线观看| 欧美日韩久久不卡| 欧美一区二区三区视频在线| 日韩欧美另类在线| 久久久国产综合精品女国产盗摄| 国产午夜精品在线观看| 国产精品伦一区二区三级视频| 国产精品视频一二| 日韩码欧中文字| 亚洲一区二区三区激情| 日本vs亚洲vs韩国一区三区| 国产一区二区三区久久久| 国产成人免费视频| 色噜噜偷拍精品综合在线| 欧美揉bbbbb揉bbbbb| 精品国产3级a| 国产亚洲欧洲997久久综合| 亚洲国产成人私人影院tom| 亚洲美女一区二区三区| 亚洲va欧美va天堂v国产综合| 美国十次综合导航| 国产成人免费xxxxxxxx| 欧美综合天天夜夜久久| 日韩亚洲欧美综合| 国产精品女主播av| 一区二区欧美在线观看| 日韩成人午夜电影| voyeur盗摄精品| 欧美日韩精品免费观看视频 | 欧美视频第二页| www成人在线观看| 一区二区欧美在线观看| 国产精选一区二区三区| 日本福利一区二区| 国产校园另类小说区| 亚洲妇女屁股眼交7| 高清视频一区二区| 欧美人与性动xxxx| 中文字幕日韩欧美一区二区三区| 午夜日韩在线电影| 精品99一区二区| 亚洲一区二区偷拍精品| 国产成人自拍网| 56国语精品自产拍在线观看| 国产精品免费久久| 另类调教123区| 欧美中文一区二区三区| 国产精品日日摸夜夜摸av| 日韩精品亚洲专区| 色噜噜夜夜夜综合网| 欧美高清在线精品一区| 激情欧美一区二区| 欧美日韩国产综合一区二区三区 | 亚洲国产精品精华液网站| 成人免费观看av| 日韩精品一区在线| 石原莉奈一区二区三区在线观看| av色综合久久天堂av综合| 2023国产一二三区日本精品2022| 亚洲成人动漫av| 91在线播放网址| 国产精品色婷婷| 国产91精品一区二区麻豆网站| 欧美一区二区福利在线| 亚洲h在线观看| 91高清视频免费看| 亚洲免费成人av| 不卡电影一区二区三区| 国产三级精品三级| 国产电影精品久久禁18| 久久久久久免费毛片精品| 美女视频第一区二区三区免费观看网站| 欧美性一级生活| 艳妇臀荡乳欲伦亚洲一区| 色婷婷久久一区二区三区麻豆| 国产精品第13页| 91老司机福利 在线| 亚洲精品欧美在线| 91久久精品日日躁夜夜躁欧美| 亚洲婷婷在线视频| 91欧美激情一区二区三区成人| 国产精品久久三区| 91在线视频官网| 尤物视频一区二区| 91福利国产精品| 午夜精品在线视频一区| 欧美一区二区三区在线观看视频 | 欧美日韩高清一区二区| 亚洲成人第一页| 日韩欧美中文一区二区| 久久99精品国产.久久久久久| 亚洲精品一区二区三区精华液| 日本欧美一区二区| 精品欧美久久久| 成人精品视频一区二区三区尤物| 国产精品乱码久久久久久| 91在线丨porny丨国产| 亚洲一区二区三区在线看| 欧美一区二区啪啪| 国产一区二区三区黄视频| 中文字幕精品一区二区三区精品 | 欧美日韩你懂得| 秋霞电影一区二区| 久久噜噜亚洲综合| 99re热这里只有精品免费视频| 亚洲一区二区三区国产| 欧美一级一区二区| 国产成人小视频| 一区二区三区在线不卡| 91精品国产综合久久精品性色| 久久99国产精品麻豆| 国产精品毛片无遮挡高清| 欧美午夜精品一区二区蜜桃| 国内精品不卡在线| 亚洲精品少妇30p|