用字母树实现一个存储单词的词库

这是一篇关于如何利用字母树(Trie)数据结构设计一个存储百万单词的词库的文章,旨在实现高效的单词查询。文章介绍了如何实现WordFilter接口,包含addWord和isMatch两个方法,用于添加单词到数据结构以及判断输入字符串是否包含词库中的单词。
摘要由CSDN通过智能技术生成

偶然做到一道面试题,想到用字母树来做词库存储的数据结构,感觉这样查询效率挺高的,代码有错误欢迎指正,题目如下:
设计⼀个数据结构WordFilter,⽤来存储含有百万量级单词的词库,并尽可能⾼效
的判断给定⼀个字符串中是否含有词库中的某个单词。
该数据结构基本定义如下:
public class WordFilter
{
//请⾃⾏定义⽤于存储单词的数据结构
//…
//添加⼀个词库中的单词word到你的⾃定义存储结构中
public void addWord(String word){}
//判断给你的字符串input中是否含有词库中的某个单词,
//只要含有任意⼀个就返回true,否则返回false
public boolean isMatch(String input){}
}
请实现WordFilter中的两个接⼝。备注:假设基础数据结构(链表、数组、字符
串、树、堆、哈希Map等)可直接使⽤。

word存储示例
单词“word”存储示例

public class WordFilter {
//请⾃⾏定义⽤于存储单词的数据结构
	class Letters {
		boolean is = false;//字母是否存在
		Letters[] nextlet;
		boolean end = false;//是否为单词结尾
		Letters(boolean is) {
			this.is = is;
			nextlet = new Letters[26]; //下一个字母树
			
		}
	}

	static Letters[] lets = new Letters[26];//只包含26个小写字母,可以再添加别的字符

//添加⼀个词库中的单词word到你的⾃定义存储结构中
	public void addWord(String word) {
		Letters[] nlets = lets;
		for (int i = 0; i < word.length(); i++) {
			if(nlets[word.charAt(i) - 97]==null) {
				nlets[word.charAt(i) - 97] = new Letters(true);
			}
			
			if(i==word.length()-1) {
				nlets[word.charAt(i) - 97].end=true;
			}
			nlets = nlets[word.charAt(i) - 97].nextlet;
			
		}
	}

//判断给你的字符串input中是否含有词库中的某个单词,
//只要含有任意⼀个就返回true,否则返回false
	public boolean isMatch(String input) {
		Letters[] nlets = lets;
		for (int i = 0; i < input.length(); i++) {
			if (nlets[input.charAt(i) - 97] != null) {
				if (nlets[input.charAt(i) - 97].is) {
					if(nlets[input.charAt(i) - 97].end) {
						return true;
					}else nlets = nlets[input.charAt(i) - 97].nextlet;
					
					
				} else {
					return false;
				}
			} else
				return false;

		}
		return false;
		
	}

	public static void main(String[] args) {
		WordFilter wf = new WordFilter();
		//测试代码
		wf.addWord("word");
		wf.addWord("worda");
		System.out.println(wf.isMatch("w"));
		System.out.println(wf.isMatch("word"));
		System.out.println(wf.isMatch("wordabcd"));
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值