diff options
-rw-r--r-- | 6.2/main.c | 11 | ||||
-rw-r--r-- | 6.2/tree.c | 42 | ||||
-rw-r--r-- | 6.2/tree.h | 4 |
3 files changed, 33 insertions, 24 deletions
@@ -12,14 +12,17 @@ int main(int argc, char *argv[]) { struct tnode *root; char word[MAXWORD]; + int found = NO; int bar; bar = (--argc && (**++argv == '-')) ? atoi(argv[0]+1) : DEFLEN; root = NULL; - while (getword(word, MAXWORD) != EOF) - if ((isalpha(word[0]) || (word[0] == '#' && isalpha(word[1]))) && - strlen(word) > (size_t) bar) - root = naddtree(root, word, bar, NO); + while (getword(word, MAXWORD) != EOF) { + if ((isalpha(word[0]) || (word[0] == '#' && isalpha(word[1]))) + && strlen(word) > (size_t) bar) + root = naddtree(root, word, bar, &found); + found = NO; + } ntreeprint(root); treefree(root); @@ -3,7 +3,11 @@ #include <string.h> #include "tree.h" -struct tnode *naddtree(struct tnode *p, char *w, int bar, int prevmatch) +char *sneed_strdup(char *s); +struct tnode *talloc(void); +int compare(char *w, struct tnode *p, int bar, int *found); + +struct tnode *naddtree(struct tnode *p, char *w, int bar, int *found) { int cond; @@ -11,19 +15,14 @@ struct tnode *naddtree(struct tnode *p, char *w, int bar, int prevmatch) p = talloc(); p->word = sneed_strdup(w); p->count = 1; - p->match = prevmatch; + p->match = *found; p->left = p->right = NULL; - } else { - if ((!strncmp(p->word, w, bar) && strcmp(p->word, w))) - p->match = prevmatch = YES; - - if ((cond = strcmp(w, p->word)) == 0) { - p->count++; - } else if (cond < 0) { - p->left = naddtree(p->left, w, bar, prevmatch); - } else if (cond > 0) { - p->right = naddtree(p->right, w, bar, prevmatch); - } + } else if ((cond = compare(w, p, bar, found)) == 0) { + p->count++; + } else if (cond < 0) { + p->left = naddtree(p->left, w, bar, found); + } else if (cond > 0) { + p->right = naddtree(p->right, w, bar, found); } return p; @@ -41,10 +40,8 @@ void ntreeprint(struct tnode *p) void treefree(struct tnode *p) { if (p != NULL) { - if (p->left != NULL) - treefree(p->left); - if (p->right != NULL) - treefree(p->right); + treefree(p->left); + treefree(p->right); free(p->word); free(p); } @@ -65,3 +62,14 @@ char *sneed_strdup(char *s) return p; } + +int compare(char *w, struct tnode *p, int bar, int *found) +{ + int cond; + + if ((cond = strncmp(w, p->word, bar)) == 0) + if ((cond = strcmp(w + bar, p->word + bar)) != 0) + p->match = *found = YES; + + return cond; +} @@ -13,8 +13,6 @@ enum { NO, YES }; #define TREE_H #endif -struct tnode *naddtree(struct tnode *p, char *w, int bar, int prevmatch); +struct tnode *naddtree(struct tnode *p, char *w, int bar, int *found); void ntreeprint(struct tnode *p); void treefree(struct tnode *p); -struct tnode *talloc(void); -char *sneed_strdup(char *s); |