昨天刚参加了腾讯2015年在线模拟考;
四道大题的第一题就是单词统计程序的设计思想;
为了记住这一天,我打算今天通过代码实现一下;
我将用到的核心数据结构是二叉树;
(要是想了解简单二叉树的实现,可以参考我的另一篇文章:http://www.cnblogs.com/landpack/p/4783120.html)
Problem
我需要统计的单词是在程序直接硬编码的;
这样做得原因是省略了文件输入输出所带来的困惑;
我的每篇文章,一般只说一个主题;
这样也方便我日后复习;
Solution
首先,我们需要定义一个结构体,如下代码所示:
const int LONGEST_WORD = 32; // The longest word size struct binary_tree { char str[LONGEST_WORD]; int count; struct binary_tree * left; struct binary_tree * right; }; typedef struct binary_tree node;
注意到,我们假设最长的单词定义为一个常量,在这里我觉得目前32这个长度应该可以啦;
如果要统计的文章是化学论文,建议你再加大数字,因为化学式通常都很长;
然后是,我们的结构体;这应该很容易理解的;
由于C语言没有提供我想要的BOOL类型,因此自己动手写啦下面的代码;
这个定义非常有用,通常它比define更加值得推荐;
enum BOOL { NO, YES }; typedef enum BOOL BOOL;
接下来,我们需要知道单词之间是如何比较大小的;
因此,需要一个函数叫做cmp;
代码实现如下:
BOOL cmp(char * s, char * t) { int i; for (i = 0; s[i] == t[i]; i++) if ( s[i] == '