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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? algo8-1.c

?? C語言
?? C
字號:
 /* algo8-1.c 邊界標(biāo)識法。實現(xiàn)算法8.1的程序 */
 #include"c1.h"
 #include"c8-1.h"
 #define MAX 1000 /* 可利用空間的大小(以WORD的字節(jié)數(shù)為單位) */
 #define e 10 /* 塊的最小尺寸-1(以WORD的字節(jié)數(shù)為單位) */

 Space AllocBoundTag(Space *pav,int n) /* 算法8.1(首次擬合法) */
 { /* 若有不小于n的空閑塊,則分配相應(yīng)的存儲塊,并返回其首地址;否則返回NULL */
   /* 若分配后可利用空間表不空,則pav指向表中剛分配過的結(jié)點的后繼結(jié)點 */
   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結(jié)點的后繼結(jié)點 */
     if(p->size-n<=e) /* 整塊分配,不保留<=e的剩余量 */
     {
       if(*pav==p) /* 可利用空間表變?yōu)榭毡?*/
         *pav=NULL;
       else /* 在表中刪除分配的結(jié)點 */
       {
         (*pav)->a.llink=p->a.llink;
         p->a.llink->rlink=*pav;
       }
       p->tag=f->tag=1; /* 修改分配結(jié)點的頭部和底部標(biāo)志 */
     }
     else /* 分配該塊的后n個字(高地址部分) */
     {
       f->tag=1; /* 修改分配塊的底部標(biāo)志 */
       p->size-=n; /* 置剩余塊大小 */
       f=FootLoc(p); /* 指向剩余塊底部 */
       f->tag=0; /* 設(shè)置剩余塊底部 */
       f->a.uplink=p;
       p=f+1; /* 指向分配塊頭部 */
       p->tag=1; /* 設(shè)置分配塊頭部 */
       p->size=n;
     }
     return p; /* 返回分配塊首地址 */
   }
 }

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

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

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

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

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜乳av一区二区| 欧美精品在线观看一区二区| 一本一本大道香蕉久在线精品 | 欧美日韩一区二区不卡| 精品久久久久香蕉网| 一区二区三区四区在线免费观看 | 视频在线观看国产精品| 国产福利一区二区三区视频| 欧美午夜宅男影院| 中文字幕一区av| 国产精品一区二区三区乱码| 69p69国产精品| 亚洲国产精品一区二区尤物区| 国产99一区视频免费| 精品剧情在线观看| 美女视频第一区二区三区免费观看网站| 91蜜桃在线观看| 国产精品久久久久久一区二区三区| 九色porny丨国产精品| 91麻豆精品国产91久久久| 一区二区高清免费观看影视大全 | 一区二区三区91| 成人av资源在线| 国产精品日韩成人| 懂色中文一区二区在线播放| 久久蜜桃一区二区| 国产老肥熟一区二区三区| 日韩欧美国产三级| 国产一区在线观看视频| 精品久久久久久久久久久久久久久久久 | 国产欧美一区二区三区鸳鸯浴| 美女视频黄a大片欧美| 91精品国产综合久久久久久久 | 成人白浆超碰人人人人| 亚洲v日本v欧美v久久精品| 欧美三区在线观看| 激情欧美一区二区三区在线观看| 欧美一区二区三区播放老司机| 国产精品国产三级国产三级人妇| 国产一区美女在线| 欧美性大战久久久久久久蜜臀| 欧美一级专区免费大片| 丁香五精品蜜臀久久久久99网站| 亚洲高清在线视频| 成人免费一区二区三区视频 | 久久中文娱乐网| 欧美最新大片在线看| 粉嫩久久99精品久久久久久夜| 天天影视网天天综合色在线播放| 国产精品色婷婷久久58| 精品免费视频.| 欧美一区二区三区人| 色视频欧美一区二区三区| 国产91综合一区在线观看| 秋霞av亚洲一区二区三| 一区二区三区在线观看动漫| 国产日韩欧美一区二区三区乱码| 日韩欧美资源站| 欧美丰满一区二区免费视频| 色婷婷香蕉在线一区二区| www.色精品| av不卡免费在线观看| 国产精品综合一区二区三区| 精品亚洲成a人| 理论电影国产精品| 久久国产综合精品| 免费三级欧美电影| 亚洲国产精品一区二区尤物区| 亚洲女人小视频在线观看| 亚洲天天做日日做天天谢日日欢| 中文字幕欧美激情| 国产精品久久一卡二卡| 国产精品理伦片| 国产精品久久国产精麻豆99网站 | 色综合久久久久综合99| 波多野结衣欧美| 91在线观看一区二区| 国产成人a级片| proumb性欧美在线观看| 99热这里都是精品| 91国产精品成人| 欧美性视频一区二区三区| 日本韩国精品一区二区在线观看| 91蝌蚪porny| 欧美午夜免费电影| 欧美一级在线免费| 亚洲精品在线网站| 国产片一区二区| 国产精品电影一区二区| 亚洲激情在线激情| 日韩影院在线观看| 极品少妇一区二区三区精品视频| 国产精品一品视频| 91视频观看视频| 在线播放国产精品二区一二区四区| 欧美日韩电影在线| 日韩精品一区在线观看| 欧美极品xxx| 亚洲精品国产精品乱码不99| 日韩高清一级片| 国产一区二区导航在线播放| 99这里只有精品| 51精品视频一区二区三区| 久久久久国产精品人| 国产精品初高中害羞小美女文 | 日本成人中文字幕| 国产东北露脸精品视频| 色综合视频在线观看| 911精品国产一区二区在线| 久久久精品免费免费| 亚洲欧美国产高清| 青青青伊人色综合久久| 国产成人精品免费视频网站| 欧美午夜精品理论片a级按摩| 精品国产成人在线影院| 亚洲精品国产高清久久伦理二区| 老司机精品视频一区二区三区| jiyouzz国产精品久久| 91精品黄色片免费大全| 中文字幕高清不卡| 日本中文在线一区| 欧美精品在线观看播放| 国产午夜精品美女毛片视频| 一区二区免费视频| 粉嫩一区二区三区在线看| 欧美三片在线视频观看 | 17c精品麻豆一区二区免费| 午夜久久久久久久久久一区二区| 国产精品一色哟哟哟| 欧美性感一区二区三区| 国产精品久久毛片| 麻豆精品在线视频| 欧美三区在线观看| 成人免费在线观看入口| 国模冰冰炮一区二区| 欧美无乱码久久久免费午夜一区| 国产午夜亚洲精品不卡| 麻豆精品国产传媒mv男同| 欧美亚洲一区三区| 亚洲欧洲av色图| 国产成人av一区二区三区在线| 欧美一区二区视频网站| 一区二区三区在线观看欧美| 白白色 亚洲乱淫| 久久一区二区三区四区| 秋霞电影一区二区| 56国语精品自产拍在线观看| 一区二区三区久久| 色综合久久综合网欧美综合网| 国产精品网站一区| 国产乱人伦偷精品视频免下载| 日韩欧美国产wwwww| 日韩精品午夜视频| 欧美精品久久天天躁| 亚洲国产成人av网| 精品视频在线免费观看| 亚洲久本草在线中文字幕| 99re热视频精品| 成人欧美一区二区三区1314| 成人av资源在线观看| 国产精品久久久久aaaa| www.欧美日韩国产在线| 国产亚洲一区字幕| 成人在线视频一区| 欧美国产日韩a欧美在线观看| 国产激情91久久精品导航| 欧美精品一区二| 国产成人一级电影| 国产精品无遮挡| 91丨porny丨在线| 一区二区三区在线免费视频| 欧美性大战久久| 日韩 欧美一区二区三区| 欧美xxxxxxxxx| 激情欧美一区二区| 国产视频视频一区| 成人国产精品视频| 日韩毛片在线免费观看| 在线一区二区三区四区五区| 亚洲国产精品久久人人爱蜜臀| 欧美日韩国产天堂| 男人操女人的视频在线观看欧美| 日韩小视频在线观看专区| 久久97超碰国产精品超碰| 欧美不卡激情三级在线观看| 国产麻豆精品在线观看| 国产精品久久三| 欧美性三三影院| 另类的小说在线视频另类成人小视频在线 | 一级中文字幕一区二区| 色av成人天堂桃色av| 亚洲高清在线视频| 日韩三级在线观看| 国产激情精品久久久第一区二区| 亚洲va在线va天堂| 日韩欧美一二区| eeuss鲁一区二区三区| 一片黄亚洲嫩模| 欧美成人官网二区| 91丨九色porny丨蝌蚪|