Pku acm 1002 487-3279 排序算法解题报告(一) ----二叉查找数(BST)

题意就是输入几组字符串,按照给出的形式转换为统一格式,然后输出出现多于一次的字符串出现的次数,输出时按照升序排列。由于题目中处理了大量的字符串,这里采用了二叉查找树(BST)来解决本题。
二叉查找树(BST)也称为二叉搜索树,二叉查找树或者是一棵空树,或者是具有下列性质的二叉树:
1、每个结点都有一个作为查找依据的关键码(key)。
2、左子树(如果存在)上所有结点的关键码都小于等于根结点的关键码。
3、右子树(如果存在)上所有结点的关键码都大于等于根结点的关键码。
4、左子树和右子树也是二叉查找树。
关于二叉查找树(BST),算法导论12章讲的很清楚。
 
本题的具体过程是:向二叉查找树插入元素,最后中序遍历,中序遍历的结果即是排好序的结果。这道题涉及到字符串的处理,最后要注意输出的时候注意0的处理!输出的格式为:
printf("%03d-%04d %d/n",key[x]/10000,key[x]%10000,times[x]);
关于二叉查找数的程序和带有详细注释的代码可以从 http://download.csdn.net/user/china8848/ 获得。

你可能感兴趣的:(Pku acm 1002 487-3279 排序算法解题报告(一) ----二叉查找数(BST))