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

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

?? btree.cpp

?? 基于 B- 樹實現的圖書管理系統1.rar
?? CPP
字號:
#include "btree.h"


//復制結點,將某個結點的值復制到另外一個值上
void KeyTypeCopy(KeyType &bak,KeyType k){
	bak.key = k.key;
	strcpy(bak.bname,k.bname);
	bak.left = k.left;
	bak.total = k.total;
	strcpy(bak.writter,k.writter);
	bak.user = k.user;
}

//在一個結點中查找元素,返回結點的位置
int Search(BTree p, KeyType K) {	
	if(!p)
		return -1;
	int i=0;
    for(i = 0; i < p->keynum && p->key[i+1].key <= K.key; i++);
    return i;
}

// 在m階B樹T上查找關鍵字K,返回結果(pt,i,tag)
Result SearchBTree(BTree T, KeyType K){ 
   BTree p, q;
   int found, i;
   Result R;
   //初始化變量
   p = T; 
   q = NULL; 
   found = FALSE; 
   i = 0; 
   // 初始化,p指向待查結點,q指向p的雙親
   while (p && !found) {
      i = Search(p, K); 
      // 找到待查關鍵字                  
      if (i > 0 && p->key[i].key == K.key) 
		  found = TRUE;    
      else { 
		  q = p;  
		  p = p->ptr[i]; //在另一個分支上查找
	  }
   }
   if (found) {  // 查找成功
     R.pt = p; 
	 R.i = i;  
	 R.tag = 1;  
   } 
   else {      // 查找不成功
     R.pt = q;  
	 R.i = i; 
	 R.tag = 0; 
   }
   // 返回結果信息: K的位置(或插入位置)
   return R;              
}

//插入一條記錄
void Insert(BTree &q, int i, KeyType x, BTree ap) {
	int n = q->keynum;	
	for (int j = n; j > i; j--) { //騰出空間		
		KeyTypeCopy(q->key[j + 1],q->key[j]); //復制結點值
		q->ptr[j + 1] = q->ptr[j];
	}
	KeyTypeCopy(q->key[i + 1],x);	
	q->ptr[i + 1] = ap;
	if (ap) 
		ap->parent = q;  
	q->keynum++;
}

//分離結點
void split(BTree &q, int s, BTree &ap) {
  int i,j,n = q->keynum;
  ap = (BTree)malloc(sizeof(BTNode));
  ap->ptr[0] = q->ptr[s];
  for (i = s + 1,j = 1; i <= n; i++,j++) {
	KeyTypeCopy(ap->key[j],q->key[i]);
    ap->ptr[j] = q->ptr[i];
  }
  ap->keynum = n - s;
  ap->parent = q->parent;
  for (i = 0; i <= n - s; i++)     
    if (ap->ptr[i]) 
		ap->ptr[i]->parent = ap;
  q->keynum = s-1;
}



//生成一個新的樹結點
void NewRoot(BTree &T, BTree p, KeyType x, BTree ap) {
  T = (BTree)malloc(sizeof(BTNode));

  T->keynum = 1;  //設置當前結點的元素個數
  T->ptr[0] = p;  //設置左邊結點的樹根
  T->ptr[1] = ap;  //設置右邊的樹根  
  KeyTypeCopy(T->key[1],x);  //將 x 元素的結點值復制到 T 的第一個元素中
  //當孩子不空的時候就設置當前結點為孩子的雙親
  if (p) 
	  p->parent= T;        
  if (ap) 
	  ap->parent = T;  
  T->parent = NULL;  //當前結點的雙親為空
}

//返回 false 表示在原有結點上增加數量,返回 true 表示創建了一個新的結點
Status InsertBTree(BTree &T, KeyType K) {
  // 在m階B樹T上結點*q的key[i]與key[i+1]之間插入關鍵字K。
  // 若引起結點過大,則沿雙親鏈進行必要的結點分裂調整,使T仍是m階B樹。
  BTree ap;
  Result rs;
  BTree q;
  int i;
  char addnum;
  int finished, needNewRoot, s;
  // T是空樹(參數q初值為NULL)
  KeyType x;
  //如果 T 結點為空就生成一個新的結點
  if (!T){                      
    NewRoot(T, NULL, K, NULL); 
  }
  else {
	//查找元素 k 在樹中的位置
    rs = SearchBTree(T,K);
	q = rs.pt; //查找到包含元素 k 的結點
    i = rs.i;  //元素 k 在樹中的位置
    if(rs.tag == 1){  //判斷該元素在樹中是否存在
		if(strcmp(q->key[i].bname,K.bname) != 0){
			printf("\n\t\t\t錄入失敗,原因:\n");
			printf(".\t\t\t書號沖突,請重新為該書編號!\n\n");
			printf("\t\t\t已經存在書號為 %d 的書為:\n",q->key[i].key);
			ShowBookMess(q->key[i]);
			writeLog("錄入書號 " +itos(K.key)+" 失敗!原因:錄入的書號和庫存量中的書號沖突!");
			return FALSE;
		}
	    printf("\n\t\t\t該書已經存在!\n\n");
		printf("\t\t\t是否增加其總量(y/n):");
		scanf("%s",&addnum);
		if(addnum == 'Y' || addnum == 'y'){
			q->key[i].total += K.total; //將總量增加
		    q->key[i].left += K.left;  //將剩余量增加
		    printf("\n\n\t\t\t增加總量后該書的信息如下\n");
			writeLog("增加書號 " +itos(K.key)+" 的總量!");
		}	
		else{
			printf("\n\t\t\t該書的信息如下:\n");
			writeLog("錄入書號 "+itos(K.key)+" 失敗!原因:庫存量中已經存在該書!");
		}
		ShowBookMess(q->key[i]);
	    return FALSE;
	}
    x = K;  
	ap = NULL; 
	finished = needNewRoot = FALSE;     
    while (!needNewRoot && !finished) {
      Insert(q, i, x, ap);  //插入結點
      if (q->keynum < m) 
		  finished = TRUE;  // 插入完成
      else {  // 分裂結點*q
        s = (m+1)/2;   
		split(q, s, ap);  
		x = q->key[s];
        if (q->parent) {  // 在雙親結點*q中查找x的插入位置
          q = q->parent; 
		  i = Search(q, x);  
        } 
		else 
			needNewRoot = TRUE;
      } // else
    } // while
    if (needNewRoot)        // 根結點已分裂為結點*q和*ap
      NewRoot(T, q, x, ap); // 生成新根結點*T,q和ap為子樹指針
  }
  writeLog("錄入 "+itos(K.key)+" 成功!");
  return OK;
}

//一個結點在雙親中的位置,返回其位置 i
int position(BTree T){
	if(!T){
		return 0;
	}
	int i = 0;
	if(T->parent){
		while(i <= T->parent->keynum){
			if(T == T->parent->ptr[i])
				return i; //返回當前的位置
			i++;
		}
	}
	return -1;
}

//調整樹的結構
Status fix(BTree &root,BTree p){
	int i = position(p);  //取得p 在雙親中的位置
	int mid = (m + 1)/2 - 1;  //要交換的臨界點
	BTree temp = NULL;
	int k;
	if(i > 0 && root->ptr[i - 1]->keynum > mid){  //當 i 大于零的時候就可以向左借
		temp = root->ptr[i - 1]; //比自己小的兄弟結點
		p->keynum++; //增加一個結點
		for(k = p->keynum;k > 1;k--){
			KeyTypeCopy(p->key[k],p->key[k - 1]); //將前面的結點后移一位
		}
		if(p->ptr[0]){
			for(k = p->keynum;k >= 1;k--){
				p->ptr[k] = p->ptr[k - 1]; //將要移動的結點的子結點向后移動
			}
		}
		KeyTypeCopy(p->key[1],root->key[i]); //將雙親的結點復制到根
		KeyTypeCopy(root->key[i],temp->key[temp->keynum]); //將小兄弟結點的最大的那個移動到雙親中
		if(temp->ptr[temp->keynum]){  //將兄弟結點的子結點也復制過來
			p->ptr[0] = temp->ptr[temp->keynum]; 
			temp->ptr[temp->keynum]->parent = p; //修改指向雙親的結點
			temp->ptr[temp->keynum] = NULL;
		}
		temp->keynum--;  //將左兄弟刪除一個結點
		return OK;
	}
	if(i < root->keynum && root->ptr[i + 1]->keynum > mid){ //當 i 小于最大數量的時候就可以向右借
		temp = root->ptr[i + 1];
		p->keynum++;  //增加結點的個數
		KeyTypeCopy(p->key[p->keynum],root->key[i + 1]); //將根結點的值復制過來
		KeyTypeCopy(root->key[i + 1],temp->key[1]);  //將右兄弟的結點復制過來
		for(k = 1;k < temp->keynum;k++){
			KeyTypeCopy(temp->key[k],temp->key[k + 1]); //將后面的結點向前移動一位
		}
		if(temp->ptr[0]){
			p->ptr[p->keynum] = temp->ptr[0];
			temp->ptr[0]->parent = p;  //修改指向雙親的結點
			for(k = 0;k < temp->keynum;k++){ //將子結點向前移動
				temp->ptr[k] = temp->ptr[k + 1];
			}
			temp->ptr[k + 1] = NULL;   //將刪除的結點的子結點置為空
		}
		temp->keynum--;  //將右兄弟刪除一個結點
		return OK;
	}
	return FALSE;
}

//合并結點
Status combine(BTree &root,BTree &p){
	int k,i = position(p);  //取得p 在雙親中的位置
	int mid = (m + 1)/2 - 1; //交換的條件
	BTree p2;
	if(i == 0){  //如果是第一個位置
		i = 1;
		p2 = root->ptr[i];
		p->keynum++; //增加一個結點
		KeyTypeCopy(p->key[p->keynum],root->key[i]); //將雙親的結點復制下來
		if(p2->ptr[0]){
			p->ptr[p->keynum] = p2->ptr[0]; //將兄弟的子結點也復制過來
			p2->ptr[0]->parent = p; //修改雙親
		}		
		for(k = i;k < root->keynum;k++){ //將雙親的結點向前移動一位
			KeyTypeCopy(root->key[k],root->key[k + 1]);
		}
		p->keynum++;
		p->key[p->keynum] = p2->key[1];
		if(p2->ptr[1]){
			p->ptr[p->keynum] = p2->ptr[1]; //將兄弟的子結點也復制過來
			p2->ptr[1]->parent = p;  //修改指向雙親的結點
		}		
		root->keynum--;
		free(p2);
		p2 = NULL;
		for(k = 1;k <= root->keynum;k++){
			root->ptr[k] = root->ptr[k + 1]; //將雙親結點子結點向前移動
		}
		root->ptr[k + 1] = NULL;
	}
	else if(i > 0){
		p2 = root->ptr[i - 1];		
		p2->keynum++;
		KeyTypeCopy(p2->key[p2->keynum],root->key[i]); //復制根結點的值到子結點中
		if(p->ptr[0]){
			p2->ptr[p2->keynum] = p->ptr[0];
			p->ptr[0]->parent = p2; //修改指向雙親的結點
		}				
		for(k = i;k < root->keynum;k++){
			KeyTypeCopy(root->key[k],root->key[k + 1]); //將結點前移
			root->ptr[k] = root->ptr[k + 1]; //將子結點前移			
		}
		root->ptr[k + 1] = NULL;
		root->keynum--;
		free(p); 
		p = p2;
	}
	return OK;
}

//與右最左結點交換
void exchange(BTree &T,int i){
	BTree p = T;
	User *user = NULL;
	if(p->ptr[i]){
		p = p->ptr[i];
		while(p->ptr[0]){
			p = p->ptr[0];		
		}
		while(T->key[i].user){
			user = T->key[i].user;  //指向要釋放的結點
			T->key[i].user = T->key[i].user->next; //指向下一個結點
			free(user);  //釋放借閱者的信息
		}
		KeyTypeCopy(T->key[i],p->key[1]);  //交換數據
	}	
	while(i < p->keynum){ //將該結點后面的數據后移
		KeyTypeCopy(p->key[i],p->key[i + 1]); //將后一個數據復制到前一個數據
		i++;
	}
	p->keynum--;  //刪除結點
	T = p;
	return;
}


//刪除樹結點
Status DeleteBTree(BTree &T,KeyType k){
	if(T == NULL){  //如果還沒有錄入過書,就直接返回
		printf("\t\t\t書庫為空!\n");
		writeLog("刪除書號為 " + itos(k.key) + " 失敗!原因:當前書的庫存量為空!");
		return FALSE;  
	}
	BTree p;    //查找到的指針
	Result rs;  //查找的結果
	int i = 0,sk = 0;
	rs = SearchBTree(T,k);  //查找
	//如果該 B- 樹中不包含該 k 就返回 false
	if(rs.tag == 0){ //如果查找失敗
		printf("\t\t\t刪除失敗!不存在你想要刪除的信息!\n");
		writeLog("刪除書號為 " + itos(k.key) +"失敗!原因:不存在你要刪除的書!");
		return FALSE;
	}
	p = rs.pt; //將查找到的結點賦值給 p
	i = rs.i;  //在結點中的位置	
	exchange(p,i); //將該結點的值和最右下左角的值交換
	if(p->keynum >= (m + 1)/2 - 1){  //這里的 1 可以用 (m+1)/2 - 1 來代替
		return OK;
	}
	//下面的表示 p->keynum == 0
	if(p == T){  //當只有根結點的時候
		free(T); //把根結點釋放掉
		T = NULL; //把刪除的結點賦值為空                      
		return OK;
	}	
	while(p){  //其他的情況
		if(p == T || p->keynum >= (m + 1)/2 - 1 || !p->parent) //如果 p 結點刪除后還有元素
			return OK;  //用于循環結束的條件
		else{  //否則就要向左右兩邊借元素
			if(fix(p->parent,p) == OK)  //判斷能不能借,可以借就直接返回
				return OK;
		}
		combine(p->parent, p);		
		p = p->parent;
		if((p == T || !p->parent) && p->keynum == 0){  //如果合并后父結點變成空
			T = p->ptr[0];
			free(p);
			p = T;
			T->parent = NULL;
			return OK;
		}		
	}
	return OK;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本久久a久久免费精品不卡| 成人黄色电影在线 | 欧美一区二区视频在线观看2020| 国产超碰在线一区| 国产成人亚洲综合a∨猫咪| 久久国产乱子精品免费女| 日本一道高清亚洲日美韩| 亚洲成人av一区二区三区| 亚洲一区二区三区美女| 亚洲午夜在线视频| 亚洲国产视频直播| 日韩精品欧美精品| 美女任你摸久久| 麻豆精品视频在线观看免费| 韩国一区二区在线观看| 高清不卡一区二区在线| 99久久99久久综合| 欧美在线观看一区| 欧美电影影音先锋| 精品国产一区二区亚洲人成毛片| 久久婷婷国产综合国色天香| 亚洲国产精品成人综合| 亚洲色图20p| 午夜精品福利一区二区三区蜜桃| 久久精品国产一区二区三| 国产一区二区精品久久91| 风间由美一区二区av101| 91丨九色丨蝌蚪丨老版| 欧美欧美午夜aⅴ在线观看| 欧美第一区第二区| 国产精品卡一卡二| 日韩av中文在线观看| 国产一区二区日韩精品| 91一区二区三区在线播放| 911精品国产一区二区在线| 欧美xxxx在线观看| 亚洲青青青在线视频| 日韩av二区在线播放| 国v精品久久久网| 欧美三级视频在线观看| 久久久不卡网国产精品二区| 亚洲婷婷综合久久一本伊一区| 亚洲国产美女搞黄色| 国产电影精品久久禁18| 51精品国自产在线| 国产精品盗摄一区二区三区| 日本不卡视频在线| 一本色道久久综合亚洲91| 精品久久免费看| 亚洲制服丝袜av| 国产69精品久久久久777| 欧美精品日日鲁夜夜添| 国产精品三级在线观看| 久久成人精品无人区| 99re这里都是精品| 精品欧美乱码久久久久久1区2区| 亚洲精品国产品国语在线app| 国产一区二区三区精品视频| 91麻豆精品国产91久久久久久| 亚洲婷婷国产精品电影人久久| 国产在线视频精品一区| 欧美一级二级三级乱码| 亚洲一区中文日韩| 91麻豆国产福利精品| 国产精品天美传媒沈樵| 国产精品白丝jk黑袜喷水| 精品久久国产老人久久综合| 午夜精品一区二区三区电影天堂 | 亚洲www啪成人一区二区麻豆| 成人黄动漫网站免费app| 久久精品在线观看| 另类小说图片综合网| 日韩一级在线观看| 日本三级韩国三级欧美三级| 欧美日本在线播放| 亚洲国产视频在线| 韩国视频一区二区| 精品免费99久久| 午夜亚洲福利老司机| 91传媒视频在线播放| 欧美高清一级片在线观看| 麻豆国产91在线播放| 日韩欧美高清一区| 免费人成网站在线观看欧美高清| 色婷婷亚洲婷婷| 亚洲欧美视频在线观看| 成人国产精品免费观看视频| 国产偷v国产偷v亚洲高清| 天天影视色香欲综合网老头| 欧美精品久久99久久在免费线| 亚洲一区日韩精品中文字幕| 99国产精品久久久久| 成人欧美一区二区三区1314| 成人免费视频免费观看| 亚洲国产精华液网站w | 国产大陆精品国产| 久久免费国产精品| 国产激情一区二区三区| 2024国产精品| 韩国女主播成人在线观看| 久久久久久久一区| 国产不卡一区视频| 亚洲国产激情av| av在线不卡观看免费观看| 悠悠色在线精品| 欧美日韩国产高清一区二区三区 | 丝袜美腿亚洲一区二区图片| 欧美成va人片在线观看| 国产一区二区调教| 久久免费国产精品| 99久久精品国产导航| 日韩毛片在线免费观看| 欧美日韩一区三区四区| 日韩精品国产欧美| 久久先锋资源网| 在线免费观看视频一区| 视频精品一区二区| 国产网站一区二区三区| 99视频在线精品| 亚洲成人在线观看视频| www一区二区| 91成人看片片| 国产91对白在线观看九色| 亚洲电影视频在线| 久久久久久久电影| 91啪九色porn原创视频在线观看| 亚洲欧美一区二区在线观看| 欧美日韩一卡二卡| 国产一区二区三区在线观看精品| 亚洲资源在线观看| 久久精品夜色噜噜亚洲a∨| 欧美日韩国产大片| 丁香婷婷综合五月| 视频在线在亚洲| 国产精品―色哟哟| 欧美va亚洲va| 91国偷自产一区二区三区成为亚洲经典 | 色呦呦国产精品| 亚洲精品日日夜夜| 亚洲欧美综合另类在线卡通| 日韩一区二区中文字幕| 99精品黄色片免费大全| 久久丁香综合五月国产三级网站| 亚洲猫色日本管| 久久综合九色综合欧美就去吻| 色诱亚洲精品久久久久久| 亚洲成人一区在线| 亚洲午夜精品17c| 国产精品区一区二区三| 久久这里只有精品6| 欧美精品日韩一本| 91国在线观看| 99亚偷拍自图区亚洲| 波多野结衣的一区二区三区| 久久99久久久欧美国产| 日韩国产欧美在线播放| 亚洲麻豆国产自偷在线| 国产精品看片你懂得| 久久久久国产免费免费| 日韩欧美在线综合网| 日韩精品在线一区| 9191国产精品| 欧美电影在哪看比较好| 欧美二区在线观看| 欧美日产在线观看| 欧美三级三级三级爽爽爽| 欧美日韩国产中文| 欧美精品v国产精品v日韩精品| 91官网在线免费观看| 91麻豆蜜桃一区二区三区| voyeur盗摄精品| 不卡的电视剧免费网站有什么| 国产乱码精品一品二品| 9久草视频在线视频精品| 成人黄色在线看| 成人精品免费看| 成人av电影在线播放| 色综合欧美在线视频区| 欧美在线视频不卡| 欧美成人免费网站| 久久久精品tv| 国产欧美一区二区在线| 国产精品乱码一区二三区小蝌蚪| 国产精品久线在线观看| 亚洲免费在线视频一区 二区| 亚洲自拍偷拍图区| 老司机午夜精品99久久| 国产一区啦啦啦在线观看| 国产ts人妖一区二区| 91丨九色丨国产丨porny| 欧美综合一区二区| 久久久久久久久久久久久久久99 | 精品日产卡一卡二卡麻豆| 久久这里只有精品视频网| 亚洲资源在线观看| 久久精品国产99国产| 成人丝袜高跟foot| 在线精品观看国产| 日韩精品一区二区三区三区免费| 国产婷婷色一区二区三区四区 |