算法学习系列(8)—— 前缀树以及贪心算法、中位数问题

1.介绍前缀树

[问题] 何为前缀树? 如何生成前缀树?

1.1 何为前缀树:

直接举例说明:
先给定一个字符串:abc,建立一棵树,从头结点有走向a的路不?没有就见一个节点,a加在该路径上,然后b也加在后边,c继续。当再给一个字符串be的时候,从头节点开始没有通向b的路,所以重新建节点,再建路,bce添加上去。然后对于abd,有了ab,在后边加d就行。bef也是一样的道理。最终建立的这棵树就叫做前缀树(Trie[try同音]树)。
在这里插入图片描述

1.2 前缀树相关的问题

 1)arr2中有哪些字符,是arr1中出现的?请打印
 2)arr2中有哪些字符,是作为arr1中某个字符串前缀出现的?请打印
 3)arr2中有哪些字符,是作为arr1中某个字符串前缀出现的?请打印 arr2中出现次数最大的前缀。
public class Code_01_TrieTree {
   

	public static class TrieNode {
   
		public int path;//有多少个节点到达过
		public int end;//有多少个字符串结尾的
		public TrieNode[] nexts;//路

		public TrieNode() {
   
			path = 0;
			end = 0;
			nexts = new TrieNode[26];//每个节点都默认有26条路,a-z
		}
	}

	public static class Trie {
   
		private TrieNode root;

		public Trie() {
   
			root = new TrieNode();
		}

		public void insert(String word) {
   
			if (word == null) {
   
				return;
			}
			char[] chs = word.toCharArray();
			TrieNode node = root;
			int index = 0;
			for (int i = 0; i < chs.length; i++) {
   
				index = chs[i] - 'a';
				if (node.nexts[index] == null) {
   
					node.nexts[index] = new TrieNode();
				}
				node = node.nexts[index];
				node.path++;
			}
			node.end++;
		}

		public void delete(String word) {
   
			if (search(word) != 0) {
   
				char[] chs = word.toCharArray();
				TrieNode node = root;
				int index = 0;
				for (int i = 0; i < chs.length; i++) {
   
					index = chs[i] - 'a';
					if (--node.nexts[index].path == 0) {
   //如果当前的path已经等于0了,后边的节点就直接指向空就行了
						node.nexts[index] = null;
						return;
					}
					node = node.nexts[index];
				}
				node.end--;
			}
		}

		public int search(String word) {
   
			if (word == null) {
   
				return 0;
			}
			char[] chs = word.toCharArray();
			TrieNode node = root;
			int index = 0;
			for (int i = 0; i < chs.length; i++) {
   
				index = chs[i] - 'a';
				if (node.nexts[index] == null) {
   
					return 0;
				}
				node = node.nexts[index];
			}
			return node.end;
		}

		public int prefixNumber(String pre) {
   
			if (pre == null) {
   
				return 0;
			}
			char[] chs = pre.toCharArray();
			TrieNode node = root;
			int index = 0;
			for (int i = 0; i < chs.length; i++) {
   
				index = chs
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值