poj 2001(trie)

/**
 * poj 2001
 * trie字典树
 * 題意:给出n个单词(1<=n<=1000),求出每个单词的非公共前缀,如果没有,则输出自己。
 */
import java.util.*;

class Node {
	int num;
	Node[] child = new Node[26];
}

public class Main {

	final int MAX = 1005;
	Scanner sc = new Scanner(System.in);
	char[][] str = new char[MAX][21];
	Node root = new Node();

	void insert(char[] s) {
		Node node = root;
		for (int i = 0; i < s.length; i++) {
			int id = s[i] - 'a';
			if (node.child[id] == null)
				node.child[id] = new Node();
			node = node.child[id];
			node.num++;
		}
	}

	void find(char[] s) {
		Node node = root;
		System.out.print(new String(s) + " ");
		for (int i = 0; i < s.length; i++) {
			System.out.print(s[i]);
			int id = s[i] - 'a';
			if (node.child[id].num == 1)
				break;
			node = node.child[id];
		}
		System.out.println();
	}

	void init() {
		char[] s = new char[21];
		int index = 0;
		while (sc.hasNext()) {
			s = sc.next().toCharArray();
			str[index++] = s;
			insert(s);
		}
		for (int i = 0; i < index; i++) {
			find(str[i]);
		}
	}

	public static void main(String[] args) throws Exception {
		new Main().init();
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值