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

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

?? algo4-3.cpp

?? 建立索引表功能
?? CPP
字號:
 // algo4-3.cpp 根據書目文件bookinfo.txt生成書名關鍵詞索引文件bookidx.txt,
 // 為運行algo4-4.cpp做準備,算法4.9~4.14
 #include"c1.h"
 typedef int ElemType;
 #include"c2-5.h"
 #include"bo2-6.cpp"
 #include"c4-2.h"
 #include"bo4-2.cpp"

 #define MaxKeyNum 25 // 索引表的最大容量(關鍵詞的最大數目)
 #define MaxLineLen 52 // 書目串(書目文件的1行)buf的最大長度
 #define MaxNoIdx 10 // 非索引詞(也是一個書目中關鍵詞)的最大數目

 struct WordListType // 一個書目的詞表(順序表)和非索引詞表(有序表)共用類型
 {
   char *item[MaxNoIdx]; // 詞表(字符串)指針數組
   int last; // 詞的數量
 };

 struct IdxTermType // 索引項類型
 {
   HString key; // 關鍵詞(堆分配類型,c4-2.h)
   LinkList bnolist; // 存放書號索引的鏈表(c2-5.h)
 };

 struct IdxListType // 索引表類型(有序表)
 {
   IdxTermType item[MaxKeyNum+1]; // 索引項數組類型
   int last; // 關鍵詞的個數
 };

 // 全局變量
 char buf[MaxLineLen+1]; // 當前書目串(包括'\0')
 WordListType wdlist,noidx; // 暫存一種書的詞表,非索引詞表

 void InitIdxList(IdxListType &idxlist)
 { // 初始化操作,置索引表idxlist為空表,且在idxlist.item[0]設一空串
   idxlist.last=0;
   InitString(idxlist.item[0].key); // 初始化[0]單元,函數在bo4-2.cpp中
   InitList(idxlist.item[0].bnolist); // 初始化[0]單元,函數在bo2-6.cpp中
 }

 void ExtractKeyWord(int &BookNo)
 { // 從buf中提取書名關鍵詞到詞表wdlist,書號存入BookNo
   int i,l,f=1; // f是字符串buf結束標志 0:結束 1:未結束
   char *s1,*s2;
   for(i=1;i<=wdlist.last;i++)
   { // 釋放上一個書目在詞表wdlist的存儲空間
     free(wdlist.item[i]);
     wdlist.item[i]=NULL;
   }
   wdlist.last=0; // 初始化詞表wdlist的詞數量
   BookNo=atoi(buf); // 將前幾位數字轉化為整數,賦給書號BookNo
   s1=&buf[4]; // s1指向書名的首字符
   while(f)
   { // 提取書名關鍵詞到詞表wdlist
     s2=strchr(s1,' '); // s2指向s1后的第一個空格,如沒有,返回NULL
     if(!s2) // 到串尾(沒空格)
     {
       s2=strchr(s1,'\12'); // s2指向buf的最后一個字符(回車符10)
       f=0;
     }
     l=s2-s1; // 單詞長度
     if(s1[0]>='A'&&s1[0]<='Z') // 單詞首字母為大寫
     { // 寫入詞表
       wdlist.item[wdlist.last]=(char *)malloc((l+1)*sizeof(char)); // 生成串空間(包括'\0')
       for(i=0;i<l;i++)
         wdlist.item[wdlist.last][i]=s1[i]; // 寫入詞表
       wdlist.item[wdlist.last][l]=0; // 串結束符
       for(i=0;i<noidx.last&&(l=strcmp(wdlist.item[wdlist.last],noidx.item[i]))>0;i++);
       // 查找是否為非索引詞
       if(!l) // 是非索引詞
       {
         free(wdlist.item[wdlist.last]); // 從詞表中刪除該詞
         wdlist.item[wdlist.last]=NULL;
       }
       else
	 wdlist.last++; // 詞表長度+1
     }
     s1=s2+1; // s1移動到下一個單詞的首字符處
   };
 }

 void GetWord(int i,HString &wd)
 { // 用wd返回詞表wdlist中第i個關鍵詞,算法4.11
   StrAssign(wd,wdlist.item[i]); // 生成關鍵字字符串 bo4-2.cpp
 }

 int Locate(IdxListType &idxlist,HString wd,Status &b)
 { // 在索引表idxlist中查詢是否存在與wd相等的關鍵詞。若存在,則返回其
   // 在索引表中的位置,且b取值TRUE;否則返回插入位置,且b取值FALSE,算法4.12
   int i,m;
   for(i=idxlist.last;(m=StrCompare(idxlist.item[i].key,wd))>0;--i); // bo4-2.cpp
   if(m==0) // 找到
   {
     b=TRUE;
     return i;
   }
   else
   {
     b=FALSE;
     return i+1;
   }
 }

 void InsertNewKey(IdxListType &idxlist,int i,HString wd)
 { // 在索引表idxlist的第i項上插入新關鍵詞wd,并初始化書號索引的鏈表為空表,算法4.13
   int j;
   for(j=idxlist.last;j>=i;--j) // 后移索引項
     idxlist.item[j+1]=idxlist.item[j];
   InitString(idxlist.item[i].key); // bo4-2.cpp
   StrCopy(idxlist.item[i].key,wd); // 串拷貝插入新的索引項 bo4-2.cpp
   InitList(idxlist.item[i].bnolist); // 初始化書號索引表為空表 bo2-6.cpp
   idxlist.last++;
 }

 void InsertBook(IdxListType &idxlist,int i,int bno)
 { // 在索引表idxlist的第i項中插入書號為bno的索引,算法4.14
   Link p;
   MakeNode(p,bno); // 分配結點 bo2-6.cpp
   p->next=NULL;
   Append(idxlist.item[i].bnolist,p); // 插入新的書號索引 bo2-6.cpp
 }

 void InsIdxList(IdxListType &idxlist,int bno)
 { // 將書號為bno的關鍵詞插入索引表,算法4.10
   int i,j;
   Status b;
   HString wd;
   InitString(wd); // bo4-2.cpp
   for(i=0;i<wdlist.last;i++)
   {
     GetWord(i,wd);
     j=Locate(idxlist,wd,b); // 關鍵詞的位置或待插入的位置(當索引表中不存在該詞)
     if(!b) // 索引表中不存在關鍵詞wd
       InsertNewKey(idxlist,j,wd); // 在索引表中插入新的索引項
     InsertBook(idxlist,j,bno); // 插入書號索引
   }
 }

 void PutText(FILE *f,IdxListType idxlist)
 { // 將生成的索引表idxlist輸出到文件f
   int i,j;
   Link p;
   fprintf(f,"%d\n",idxlist.last);
   for(i=1;i<=idxlist.last;i++)
   {
     for(j=0;j<idxlist.item[i].key.length;j++)
       fprintf(f,"%c",idxlist.item[i].key.ch[j]); // HString類型串尾沒有\0,只能逐個字符輸出
     fprintf(f,"\n%d\n",idxlist.item[i].bnolist.len);
     p=idxlist.item[i].bnolist.head;
     for(j=1;j<=idxlist.item[i].bnolist.len;j++)
     {
       p=p->next;
       fprintf(f,"%d ",p->data);
     }
     fprintf(f,"\n");
   }
 }

 void main()
 { // 算法4.9
   FILE *f; // 任何時間最多打開一個文件
   IdxListType idxlist; // 索引表
   int BookNo; // 書號變量
   int k;
   if(!(f=fopen("NoIdx.txt","r"))) // 打開非索引詞文件
     exit(OVERFLOW);
   fscanf(f,"%d",&noidx.last); // 讀取非索引詞個數
   for(k=0;k<noidx.last;k++) // 把非索引詞文件的內容依次拷到noidx中
   {
     fscanf(f,"%s",buf);
     noidx.item[k]=(char*)malloc((strlen(buf)+1)*sizeof(char));
     strcpy(noidx.item[k],buf);
   }
   fclose(f); // 關閉非索引詞文件
   if(!(f=fopen("BookInfo.txt","r"))) // 打開書目文件
     exit(FALSE);
   InitIdxList(idxlist); // 設索引表idxlist為空,并初始化[0]單元
   while(fgets(buf,MaxLineLen,f)) // 由書目文件讀取1行信息到buf成功
   {
     ExtractKeyWord(BookNo);//將buf中的書號存入BookNo,關鍵詞提取到詞表(當前書目的關鍵詞表)中
     InsIdxList(idxlist,BookNo); // 將書號為BookNo的關鍵詞及書號插入索引表idxlist中
   }
   fclose(f); // 關閉書目文件
   if(!(f=fopen("BookIdx.txt","w"))) // 打開書名關鍵詞索引文件
     exit(INFEASIBLE);
   PutText(f,idxlist); // 將生成的索引表idxlist輸出到書名關鍵詞索引文件
   fclose(f); // 關閉書名關鍵詞索引文件
 }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品系列| 在线一区二区三区四区五区| 亚洲福利国产精品| 一区二区三区毛片| 综合久久国产九一剧情麻豆| 国产亚洲一二三区| 国产欧美日产一区| 自拍偷在线精品自拍偷无码专区| 国产精品视频观看| 国产精品欧美一区二区三区| 亚洲国产精品二十页| 欧美激情艳妇裸体舞| 欧美激情综合在线| 国产精品成人免费精品自在线观看 | 亚洲一区在线观看免费观看电影高清| 国产精品卡一卡二| 《视频一区视频二区| 亚洲视频小说图片| 亚洲国产aⅴ成人精品无吗| 视频一区免费在线观看| 日韩精品免费视频人成| 日韩高清不卡一区| 韩国成人福利片在线播放| 国产成人一区二区精品非洲| 成人国产在线观看| 欧美日韩色一区| 日韩免费在线观看| 国产精品国产自产拍高清av王其 | 色八戒一区二区三区| 精品视频在线视频| 久久网这里都是精品| 国产精品白丝在线| 日韩影视精彩在线| 国产福利一区在线| 欧美日韩精品欧美日韩精品一综合| 日韩视频123| 成人免费一区二区三区在线观看| 丝袜亚洲另类欧美| 成人av免费在线播放| 欧美日韩另类一区| 国产精品每日更新在线播放网址 | 欧美肥妇free| 国产欧美一区二区三区网站| 亚洲午夜久久久久久久久久久| 毛片av一区二区| 欧洲av在线精品| 久久精品夜色噜噜亚洲a∨| 亚洲蜜臀av乱码久久精品| 极品少妇一区二区三区精品视频| 99国产欧美另类久久久精品| 日韩欧美亚洲一区二区| 亚洲视频一二三| 激情伊人五月天久久综合| 欧美日韩一区二区在线观看视频| 国产精品毛片大码女人| 麻豆成人久久精品二区三区小说| 91国内精品野花午夜精品| 国产午夜精品一区二区三区嫩草 | av不卡免费在线观看| 欧美电影在线免费观看| 国产精品二三区| 国产一区二区在线看| 在线播放91灌醉迷j高跟美女| 成人免费一区二区三区视频 | 欧美经典一区二区| 秋霞午夜av一区二区三区| 91黄色在线观看| 亚洲人成网站色在线观看| 懂色中文一区二区在线播放| 欧美电影免费观看高清完整版在线观看| 亚洲一区免费观看| 91免费版pro下载短视频| 国产精品欧美极品| 成人理论电影网| 国产喂奶挤奶一区二区三区| 精品一区二区在线免费观看| 日韩欧美国产小视频| 三级欧美韩日大片在线看| 欧美亚洲尤物久久| 亚洲成人av在线电影| 日本韩国精品在线| 亚洲国产日韩精品| 欧美日韩免费高清一区色橹橹| 亚洲激情成人在线| 欧美性猛交xxxx黑人交| 亚洲第一久久影院| 91精品在线麻豆| 国产真实乱偷精品视频免| 亚洲精品在线电影| 国产经典欧美精品| 日本一区二区三区在线不卡| 成人高清av在线| 亚洲美女在线国产| 5566中文字幕一区二区电影| 国产.欧美.日韩| 国产欧美精品日韩区二区麻豆天美| 国产夫妻精品视频| 中文字幕亚洲在| 欧美日韩一区久久| 国产一区二区导航在线播放| 日本一二三不卡| 欧美影视一区二区三区| 蜜桃传媒麻豆第一区在线观看| www一区二区| 97精品电影院| 日韩电影在线免费观看| 久久人人爽爽爽人久久久| 91蝌蚪porny| 亚洲国产日日夜夜| 久久久久国产精品麻豆| 99精品国产99久久久久久白柏| 午夜久久久久久久久| 久久精品亚洲精品国产欧美 | 色综合久久天天| 日日摸夜夜添夜夜添国产精品 | 国产成人av电影在线观看| 综合久久国产九一剧情麻豆| 3d动漫精品啪啪一区二区竹菊| 国产sm精品调教视频网站| 一区二区三区免费观看| 久久夜色精品国产欧美乱极品| 一本色道久久综合亚洲aⅴ蜜桃| 日本成人在线网站| 亚洲美女视频在线| 久久亚洲免费视频| 在线精品视频一区二区| 国产.欧美.日韩| 乱一区二区av| 亚洲免费视频成人| 欧美国产国产综合| 日韩欧美卡一卡二| 精品视频在线免费| 99久久久久免费精品国产| 九九国产精品视频| 亚洲小少妇裸体bbw| 国产精品久久久久久久第一福利| 91精品国产综合久久久久久漫画 | 色综合天天狠狠| 国产大陆亚洲精品国产| 日韩有码一区二区三区| 亚洲免费av在线| 亚洲欧洲99久久| 国产精品久久午夜| 国产日产欧美精品一区二区三区| 欧美一区二区免费视频| 欧美日本在线一区| 在线精品视频免费播放| 91日韩在线专区| 99re8在线精品视频免费播放| 狠狠狠色丁香婷婷综合久久五月| 日本sm残虐另类| 日本vs亚洲vs韩国一区三区二区| 午夜精品一区在线观看| 亚洲一区在线免费观看| 亚洲午夜免费视频| 亚洲成人黄色影院| 日韩av电影天堂| 青青草一区二区三区| 六月丁香婷婷久久| 精品一区二区在线免费观看| 国产一区二三区好的| 国产成人免费在线| 成人久久视频在线观看| www.一区二区| 色屁屁一区二区| 欧美午夜视频网站| 91精品国产91久久久久久最新毛片| 9191久久久久久久久久久| 宅男在线国产精品| 久久男人中文字幕资源站| 欧美激情在线观看视频免费| 国产精品女同互慰在线看| 亚洲欧美在线视频| 伊人色综合久久天天人手人婷| 亚洲国产精品久久久久秋霞影院 | 国产欧美日韩另类一区| 国产精品免费视频观看| 亚洲女同一区二区| 日韩精品欧美成人高清一区二区| 精品综合久久久久久8888| 国产91富婆露脸刺激对白| 91精品91久久久中77777| 欧美精品乱码久久久久久| 精品国产免费一区二区三区四区 | 337p亚洲精品色噜噜| 久久精品亚洲一区二区三区浴池 | 日韩av一区二区在线影视| 韩日av一区二区| 色综合激情五月| 日韩免费高清av| 综合在线观看色| 午夜天堂影视香蕉久久| 国产精品一级片| 欧美性感一区二区三区| 久久久久久久久久电影| 亚洲国产cao| 成人免费毛片片v| 欧美精品免费视频| 中文字幕一区二区三区不卡| 美女看a上一区|