Hard 在字符串S中查找T中的字符串 @CareerCup

后缀树!!


package Hard;

import java.util.ArrayList;
import java.util.HashMap;


/**
 * Given a string s and an array of smaller strings T, design a method to search s for each small string in T.

译文:

给一个字符串S和一个字符串数组T(T中的字符串要比S短许多),设计一个算法, 在字符串S中查找T中的字符串。
 *
 */
public class S18_8 {

	// 后缀树节点
	static class SuffixTreeNode {
		HashMap<Character, SuffixTreeNode> children = new HashMap<Character, SuffixTreeNode>();

		char value;
		ArrayList<Integer> indexes = new ArrayList<Integer>();

		public SuffixTreeNode() {
		}

		public void insertString(String s, int index) {
			indexes.add(index);
			if (s != null && s.length() > 0) {
				value = s.charAt(0);
				SuffixTreeNode child = null;
				if (children.containsKey(value)) {
					child = children.get(value);
				} else {
					child = new SuffixTreeNode();
					children.put(value, child);
				}
				String remainder = s.substring(1);
				child.insertString(remainder, index);
			}
		}

		public ArrayList<Integer> search(String s) {
			if (s == null || s.length() == 0) {
				return indexes;
			} else {
				char first = s.charAt(0);
				if (children.containsKey(first)) {
					String remainder = s.substring(1);
					return children.get(first).search(remainder);
				}
			}
			return null;
		}
	}

	// 后缀树
	static class SuffixTree {
		SuffixTreeNode root = new SuffixTreeNode();

		public SuffixTree(String s) {
			for (int i = 0; i < s.length(); i++) {
				String suffix = s.substring(i);
				root.insertString(suffix, i);
			}
		}

		public ArrayList<Integer> search(String s) {
			return root.search(s);
		}
	}

	public static void main(String[] args) {
		String testString = "mississippi";
		String[] stringList = { "is", "sip", "hi", "sis" };
		SuffixTree tree = new SuffixTree(testString);
		for (String s : stringList) {
			ArrayList<Integer> list = tree.search(s);
			if (list != null) {
				System.out.println(s + ": " + list.toString());
			}
		}
	}

}


Ref:

http://blog.csdn.net/v_july_v/article/details/6897097

http://blog.csdn.net/at8008/article/details/17256321

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值