ZOJ-1174

19 篇文章 0 订阅

字符串匹配,这里我用了JAVA的正则,懒的去写匹配方法了,后来想了想其实匹配方法手写其实也是可以的,JAVA的时间和内存和C系真不是一个数量级的,不到万不得已还是别用了。。这里注意保存已有的word匹配结果可以大大提高效率,就是代码里那个map

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Scanner;
import java.util.regex.Pattern;

public class Main
{
	static final String PAT = "[A-Z]*";
	static Map<String, String> map = new HashMap<String, String>();

	static String find(List<String> dict, String word)
	{
		if (map.containsKey(word))
			return map.get(word);

		StringBuilder sb = new StringBuilder(PAT);
		for (char c : word.toCharArray())
			sb.append(c).append(PAT);
		Pattern p = Pattern.compile(sb.toString());
		boolean find = false;
		String res = null;
		for (String s : dict)
		{
			if (p.matcher(s).find())
			{
				if (find)
					return null;
				find = true;
				res = s;
			}
		}
		map.put(word, res);
		return res;
	}

	public static void main(String[] args)
	{
		Scanner sc = new Scanner(System.in);
		int N = sc.nextInt();
		sc.nextLine();
		List<String> dict = new ArrayList<String>();
		for (int t = 0; t < N; t++)
		{
			if (t > 0)
				System.out.println();
			int n = sc.nextInt();
			sc.nextLine();
			dict.clear();
			map.clear();
			while (n-- > 0)
				dict.add(sc.nextLine());
			String line;
			StringBuilder sb = new StringBuilder();
			while (!(line = sc.nextLine()).endsWith("#"))
				sb.append(line).append('\n');
			sb.append(line.substring(0, line.length() - 1));

			boolean can = true;
			boolean inWord = false;
			StringBuilder res = new StringBuilder();
			String word = "";
			for (char c : sb.toString().toCharArray())
			{
				if (c >= 'A' && c <= 'Z')
				{
					inWord = true;
					word += c;
				}
				else
				{
					if (inWord)
					{
						String temp = find(dict, word);
						if (temp == null)
						{
							can = false;
							break;
						}
						else
							res.append(temp);
						word = "";
					}
					res.append(c);
					inWord = false;
				}
			}
			if (inWord && can)
			{
				String temp = find(dict, word);
				if (temp == null)
					can = false;
				else
					res.append(temp);
			}
			if (can)
				System.out.println(res);
			else
				System.out.println("AMBIGUITY");
		}
		sc.close();
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值