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

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

?? bst.c

?? 該文件夾中包含了大部分經典的算法的源程序代碼
?? C
字號:
/* file name: bin_search_tree.c */
/* 利用二叉查找樹處理數據-加載、儲存、新增、刪除、修改、輸出 */

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>

/* 定義student結構 */
struct student {
	char name[20];  /* 學生姓名 */
	int score;  /* 學生成績 */
	struct student *llink;  /* 左子鏈接 */
	struct student *rlink;   /* 右子鏈接 */
};

void load_f(void);      /* 加載函數 */
void save_f(void);      /* 儲存函數 */
void insert_f(void);    /* 新增函數 */
void delete_f(void);    /* 刪除函數 */
void modify_f(void);    /* 修改函數 */
void show_f(void);      /* 輸出函數 */
void access(char [], int);  /* 將數據插入二叉查找樹 */
void removing(char []);  /* 將數據從二叉查找樹中移除 */
struct student *replace(struct student *);  /* 尋找替代節點 */

void connect(struct student *, char);  /* 調整鏈接 */
void inorder(struct student *);  /* 數據以中序法輸出 */
void preorder(struct student *, FILE *);  /* 數據以前序法寫入表 */
struct student *search(char []);  /* 查找節點 */
struct student *search_re_r(struct student *);  /* 查找右子樹替代節點 */
struct student *search_re_l(struct student *);  /* 查找左子樹替代節點 */
struct student *search_p(struct student *);  /* 查找父節點 */

struct student *root, *ptr;

void main(void)
{
	char option;
	load_f();  /* 載入文件 */
	while(1)
	{
		puts("");
		puts("********************");
		puts("     <1> insert");
		puts("     <2> delete");
		puts("     <3> modify");
		puts("     <4> show");
		puts("     <5> quit");
		puts("********************");
		printf("Enter your choice: ");
		option = getche();
		printf("\n\n");
		switch(option)
		{
			case '1':
				insert_f();
				break;
			case '2':
				delete_f();
				break;
			case '3':
				modify_f();
				break;
			case '4':
				show_f();
				break;
			case '5':
				save_f();  /* 儲存文件 */
				exit(0);
			default :
				puts("Wrong option!");
		}
	}
}

/* 加載函數,將數據文件dfile.dat加載到程序中 */
void load_f(void)
{
	FILE *fptr;
	char name[20];
	int score;
	printf("File loading...");
	if((fptr = fopen("bst.dat", "r")) == NULL)   /* 打開文件 */
	{
		puts("failed!");
		puts("Dfile.dat not found!");
		return;
	}
	while(fscanf(fptr, "%s %d", name, &score) != EOF)   /* 讀取文件數據 */
		if(strcmp(name, "") != 0)
			access(name, score);
	puts("OK!");
	fclose(fptr);   /* 關閉文件 */
}

/* 儲存文件,將二叉查找樹中的數據儲存至數據文件dfile.dat中 */
void save_f(void)
{
	FILE *fptr;
	printf("File saving...");
	if((fptr = fopen("bst.dat", "w")) == NULL)  /* 開啟文件 */
	{
		puts("failed!");
		return;
	}
	preorder(root, fptr);   /* 以前序法寫入 */
	puts("OK!");
	fclose(fptr);  /* 關閉文件 */
}

/* 新增函數,新增一筆新的數據 */
void insert_f(void)
{
	char name[20], temp[4];
	int score;
	puts("=====INSERT DATA=====");
	printf("Enter student name: ");
	gets(name);
	printf("Enter student score: ");
	gets(temp);
	score = atoi(temp);
	access(name, score);
}

/* 刪除函數,將數據從二叉查找樹中刪除 */
void delete_f(void)
{
	char name[20];
	if(root == NULL)
	{
		puts("No student record!");
		return;
	}
	puts("=====DELETE DATA=====");
	printf("Enter student name: ");
	gets(name);
	removing(name);
}

/* 修改數據,修改學生成績 */
void modify_f(void)
{
	struct student *node;
	char name[20], temp[4];
	if(root == NULL)   /* 判斷根節點是否為NULL */
	{
		puts("No student record!");
		return;
	}
	puts("=====MODIFY DATA===== ");
	printf("Enter student name: ");
	gets(name);
	if((node = search(name)) == NULL)
		printf("Student %s not found!\n", name);
	else
	{
		/* 列出原數據狀況 */
		printf("Original student name: %s\n", node->name);
		printf("Original student score: %d\n", node->score);
		printf("Enter new score: ");
		gets(temp);
		node->score = atoi(temp);
		printf("Data of student %s modified\n", name);
	}
}

/* 輸出函數,將數據輸出至屏幕 */
void show_f(void)
{
	if(root == NULL)  /* 判斷根節點是否為NULL */
	{
		puts("No student record!");
		return;
	}
	puts("=====SHOW DATA=====");
	inorder(root);  /* 以中序法輸出數據 */
}
/* 處理二叉查找樹,將新增數據插入至二叉查找樹中 */
void access(char name[], int score)
{
	struct student *node, *prev;
	if(search(name) != NULL)  /* 數據已存在則顯示錯誤 */
	{
		printf("Student %s has existed!\n", name);
		return;
	}
	ptr = (struct student *) malloc(sizeof(struct student));
	strcpy(ptr->name, name);
	ptr->score = score;
	ptr->llink = ptr->rlink = NULL;
	if(root == NULL)  /* 當根節點為NULL的狀況 */
		root = ptr;
	else   /* 當根節點不為NULL的狀況 */
	{
		node = root;
		while(node != NULL)  /* 查找數據插入點 */
		{
			prev = node;
			if(strcmp(ptr->name, node->name) < 0)
				node = node->llink;
			else
				node = node->rlink;
		}
		if(strcmp(ptr->name, prev->name) < 0)
			prev->llink = ptr;
		else
			prev->rlink = ptr;
	}
}

/* 將數據從二叉查找樹中移除 */
void removing(char name[])
{
	struct student *del_node;
	if((del_node = search(name)) == NULL)  /* 找不到數據則顯示錯誤 */
	{
		printf("Student %s not found!\n", name);
		return;
	}
	/* 節點不為樹葉節點的狀況 */
	if(del_node->llink != NULL || del_node->rlink != NULL)
		del_node = replace(del_node);
	else  /* 節點為樹葉節點的狀況 */
		if(del_node == root)
			root = NULL;
		else
			connect(del_node, 'n');
	free(del_node);  /* 釋放內存 */
	printf("Data of student %s deleted!\n", name);
}

/* 尋找刪除非樹葉節點的替代節點 */
struct student *replace(struct student *node)
{
	struct student *re_node;
	/* 當右子樹找不到替代節點,會查找左子樹是否存在替代節點 */
	if((re_node = search_re_r(node->rlink)) == NULL)
		re_node = search_re_l(node->llink);
	if(re_node->rlink != NULL)  /* 當替代節點有右子樹存在的狀況 */
		connect(re_node, 'r');
	else
		if(re_node->llink != NULL)  /* 當替代節點有左子樹存在的狀況 */
			connect(re_node, 'l');
		else  /* 當替代節點為樹葉節點的狀況 */
			connect(re_node, 'n');
	strcpy(node->name, re_node->name);
	node->score = re_node->score;
	return re_node;
}

/* 調整二叉查找樹的鏈接,link為r表示處理右鏈接,為l表處理左鏈接,
   為m則將鏈接指向NULL */
void connect(struct student *node, char link)
{
	struct student *parent;
	parent = search_p(node);   /* 查找父節點 */
	/* 節點為父節點左子樹的狀況 */
	if(strcmp(node->name, parent->name) < 0)
		if(link == 'r')   /* link為r */
			parent->llink = node->rlink;
		else  /* link

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一线二线三线精华| 亚洲男人天堂av网| 欧美人与z0zoxxxx视频| 99精品视频一区二区| 99久久精品国产观看| 成人精品免费看| av网站一区二区三区| 成人app在线观看| 99久久精品国产毛片| 2020国产精品自拍| 欧美电影精品一区二区| 精品国产一区二区在线观看| 欧美精品一区男女天堂| 国产亚洲精品中文字幕| 亚洲婷婷国产精品电影人久久| 中文字幕高清不卡| 亚洲精品日韩一| 丝袜美腿亚洲色图| 精品一区二区三区不卡| 国产东北露脸精品视频| 91免费小视频| 欧美精品v日韩精品v韩国精品v| 日韩一区二区高清| 久久久不卡影院| 亚洲美女视频在线| 免费的国产精品| 成人激情午夜影院| 在线播放91灌醉迷j高跟美女| 日韩欧美综合一区| 国产精品欧美综合在线| 亚洲一区在线看| 激情六月婷婷综合| 色域天天综合网| 欧美大片在线观看一区| 国产精品久久久久久久久免费樱桃 | 欧美三级视频在线观看| 777久久久精品| 国产丝袜美腿一区二区三区| 亚洲欧美日韩中文字幕一区二区三区| 亚洲成人自拍网| 国产91精品免费| 欧美一区二区三区在线看| 国产精品麻豆一区二区 | 日本不卡一区二区三区| 国产精品综合二区| 欧美精品丝袜久久久中文字幕| 久久免费美女视频| 日韩在线播放一区二区| 99久久精品国产麻豆演员表| 日韩精品中文字幕在线一区| 亚洲品质自拍视频| 国产精品综合久久| 777xxx欧美| 一区二区三区高清在线| 成人精品国产一区二区4080 | 蜜臀a∨国产成人精品| 99re这里都是精品| 国产亚洲成年网址在线观看| 日本不卡高清视频| 欧美日韩成人一区二区| 亚洲欧美日韩国产成人精品影院| 国产乱对白刺激视频不卡| 欧美手机在线视频| 一区二区三区资源| 91网站最新网址| 国产精品久久久久永久免费观看| 精品一区二区精品| 精品国产一区二区三区忘忧草| 手机精品视频在线观看| 欧洲一区在线观看| 亚洲综合男人的天堂| 97成人超碰视| 亚洲欧美一区二区三区孕妇| 成人美女视频在线观看| 国产欧美视频一区二区| 久久电影网电视剧免费观看| 欧美成人艳星乳罩| 国模大尺度一区二区三区| 精品国产不卡一区二区三区| 麻豆91在线播放| 久久久欧美精品sm网站| 国产成人在线视频播放| 国产精品久久久久精k8| 91小视频在线观看| 亚洲一区二区视频在线观看| 色哟哟一区二区在线观看| 玉足女爽爽91| 欧美日韩国产色站一区二区三区| 亚欧色一区w666天堂| 欧美一区二区三区喷汁尤物| 免费人成在线不卡| 国产校园另类小说区| 不卡电影一区二区三区| 亚洲综合网站在线观看| 7777精品伊人久久久大香线蕉的| 美美哒免费高清在线观看视频一区二区| 日韩一级完整毛片| 国产白丝精品91爽爽久久| 亚洲三级免费电影| 欧美电影一区二区三区| 国产精品99久久久久久久女警| 中文字幕视频一区| 欧美欧美欧美欧美| 国产很黄免费观看久久| 亚洲色图19p| 日韩精品一区二区三区视频| 国产成人免费在线视频| 亚洲第一成人在线| 中文字幕乱码亚洲精品一区| 色悠悠亚洲一区二区| 久久草av在线| 亚洲精品成人少妇| 国产亚洲女人久久久久毛片| 91黄视频在线观看| 国产精品一区二区久激情瑜伽| 亚洲永久精品大片| 国产网站一区二区| 欧美夫妻性生活| a亚洲天堂av| 韩国成人在线视频| 亚洲国产美国国产综合一区二区| 久久久亚洲国产美女国产盗摄 | 波多野结衣一区二区三区 | 精品日韩一区二区三区| 99re热这里只有精品视频| 热久久国产精品| 一区二区三区在线免费视频| 久久综合九色综合97_久久久| 色菇凉天天综合网| 丁香一区二区三区| 国产在线精品一区二区| 日韩在线一二三区| 亚洲一区二区三区美女| 中文字幕一区在线观看| 久久这里只精品最新地址| 91精品国产一区二区三区蜜臀| 99精品国产视频| 成人高清视频在线观看| 国产精品夜夜嗨| 久久国产精品免费| 久久精品久久99精品久久| 无码av免费一区二区三区试看 | 日韩一区二区不卡| 欧美人牲a欧美精品| 日本道色综合久久| 91在线国产福利| 成人ar影院免费观看视频| 成人午夜激情视频| 高清不卡一区二区在线| 国产一区二区0| 国产精品一区免费视频| 国产一区高清在线| 国产一区不卡视频| 风间由美一区二区av101| 国产精品亚洲午夜一区二区三区| 极品尤物av久久免费看| 国产一区在线视频| 国产乱子轮精品视频| 国产精品综合在线视频| 国产成人午夜视频| 国产白丝网站精品污在线入口| 国产91精品一区二区麻豆亚洲| 粉嫩av一区二区三区在线播放| 国产精品一二二区| av在线免费不卡| 精品视频在线视频| 日韩一级片网站| 国产午夜精品美女毛片视频| 国产亚洲欧美在线| 亚洲欧美一区二区三区久本道91 | 久久久蜜桃精品| 国产精品久久久久久久久久免费看| 国产精品乱码久久久久久| 亚洲三级在线播放| 日本亚洲最大的色成网站www| 激情综合一区二区三区| 成人av网站大全| 欧美日本在线观看| 精品88久久久久88久久久| 国产精品沙发午睡系列990531| 自拍偷拍国产亚洲| 视频一区二区国产| 国产乱人伦偷精品视频不卡| 99久久精品国产麻豆演员表| 欧美精品粉嫩高潮一区二区| 久久久久久久国产精品影院| 亚洲精品免费在线观看| 青青草伊人久久| 97久久人人超碰| 6080午夜不卡| 亚洲欧美综合在线精品| 看电视剧不卡顿的网站| 99久久99久久精品国产片果冻 | 91年精品国产| 制服丝袜亚洲播放| 亚洲欧洲精品一区二区三区 | 国产三区在线成人av| 一区二区成人在线| 高清视频一区二区| 日韩精品一区二区三区swag|