字典树 + 深搜 之 hdu 1298

//  [7/16/2014 Sjm]
/*
字典树 + 深搜。。。
(好久没碰搜索了,调试了一段时间,不过还好1A。。。)

*/

#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <map>
#include <string>
#include <functional>
using namespace std;
const int MAX = 26;

map<int, string> my_map;
string ans_str;
int max_val;
bool myJudge;

struct Trie{
	int val;
	Trie* next[MAX];
	Trie(){
		val = 0;
		memset(next, NULL, sizeof(next));
	}
};

Trie* Root;

void CreTrie(char* str, int t_val) {
	int len = strlen(str);
	Trie* p = Root;
	for (int i = 0; i < len; i++) {
		int pos = str[i] - 'a';
		if (!(p->next[pos])) {
			p->next[pos] = new Trie;
		}
		p->next[pos]->val += t_val;
		p = p->next[pos];
	}
}

void DelTrie(Trie* T)
{
	for (int i = 0; i < MAX; i++) {
		if (T->next[i]) {
			DelTrie(T->next[i]);
		}
	}
	delete[] T;
}

void Dfs_Trie(char* str, int pos, Trie* p, string for_ans_str)
{
	if (strlen(str) == pos) {
		myJudge = true;
		if (p->val > max_val) {
			ans_str = for_ans_str;
			max_val = p->val;
		}
		return;
	}
	int key = str[pos] - '0';
	int len = my_map[key].size();
	for (int i = 0; i < len; i++) {
		int now_node = my_map[key][i] - 'a';
		if (!(p->next[now_node])) {
			continue;
		}
		else {
			Dfs_Trie(str, pos + 1, p->next[now_node], for_ans_str + my_map[key][i]);
		}
	}
}

int main()
{
	my_map[2] = "abc";    my_map[3] = "def";
	my_map[4] = "ghi";    my_map[5] = "jkl";
	my_map[6] = "mno";    my_map[7] = "pqrs";
	my_map[8] = "tuv";    my_map[9] = "wxyz";
	//freopen("input.txt", "r", stdin);
	//freopen("output.txt", "w", stdout);
	int N;
	scanf("%d", &N);
	char str[105], num[105];
	int w, m, val;
	for (int i = 1; i <= N; i++) {
		printf("Scenario #%d:\n", i);

		Root = new Trie;

		scanf("%d", &w);
		while (w--) {
			scanf("%s %d", str, &val);
			CreTrie(str, val);
		}

		scanf("%d", &m);
		while (m--){
			scanf("%s", num);
			int len = strlen(num) - 1;
			char t_str[105] = { '\0' };
			for (int j = 1; j <= len; j++) {
				strncpy(t_str, num, j);
				myJudge = false;
				max_val = 0;
				Dfs_Trie(t_str, 0, Root, "");
				if (!myJudge) { printf("MANUALLY\n"); }
				else { cout << ans_str << endl; }
			}
			printf("\n");
		}
		printf("\n");
		DelTrie(Root);
	}
	return 0;
}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值