zoukankan      html  css  js  c++  java
  • 89 单词接龙

    89 单词接龙

    作者: Turbo时间限制: 1S章节: 深度优先搜索

    问题描述 :

      单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相连时,其重合部分合为一部分,例如 beast和astonish,如果接成一条龙则变为beastonish,另外,相邻的两部分不能存在包含关系,例如at 和 atide 间不能相连。

    样例输入
      5
      at
      touch
      cheat
      choose
      tact
      a

    样例输出

      23
    

    样例说明

      连成的“龙”为atoucheatactactouchoose

    输入说明 :

      输入的第一行为一个单独的整数n (n<=20)表示单词数,以下n 行每行有一个单词,输入的最后一行为一个单个字符,表示“龙”开头的字母。你可以假定以此字母开头的“龙”一定存在.

    输出说明 :

      只需输出以此字母开头的最长的“龙”的长度

    输入范例 :
    5
    at
    touch
    cheat
    choose
    tact
    a
    输出范例 :
    23

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    #include <string>
    #include <algorithm>
    using namespace std;
    const int maxn = 100;
    int n;
    int res = 0;   //拼接结果
    string word[maxn]; //字符串数组 存放单词
    string beginn;        //用来存储开头字符
    int used[maxn];     // 记录dfs时每个单词使用次数
    
    bool check(string s, string m, int k)
    {
    	int lens = (int)s.length();
    	for (int i = 0; i < k; i++)//k为接口的长度
    	{
    		if (s[lens - k + i] != m[i])
    			return false;
    	}
    	return true;
    }
    
    void add(string &tmp, string m, int k)
    {
    	int lenm = (int)m.length();
    	for (int i = k; i < lenm; i++)//从k开始拼接
    	{
    		tmp += m[i];
    	}
    }
    
    void dfs(string str)
    {
    	int len = (int)str.length();
    	res = max(res, len);//每次更新当前以拼接好的字符串长度
    	for (int i = 1; i <= n; i++)
    	{
    		if (used[i] >= 2) continue;
    		int maxlink = (int)word[i].length();//最大接口长度是当前所选单词的长度
    		for (int j = 1; j <= maxlink; j++)
    		{
    			if (check(str, word[i], j))
    			{
    				string  tmp = str;
    				add(tmp, word[i], j);//将Word【i】字符拼接到tmp中
    				if (tmp == str) continue;
    				used[i]++;
    				dfs(tmp);
    				used[i]--;
    			}
    			//else
    			//	break;
    		}
    	}
    }
    
    int main()
    {
    	cin >> n;
    	for (int i = 1; i <= n; i++)
    	{
    		cin >> word[i];
    	}
    	cin >> beginn;
    	dfs(beginn);
    
    	cout << res << endl;
    	return 0;
    }
    
    
    
    Yesterday is history,tomorrow ismystery,but today is a gift!That why it is called Present!
  • 相关阅读:
    SVN常用功能介绍(二)
    Excel文件导入SQL Server数据库
    ArcMap操作随记(2)
    ArcGIS温泉数据聚类分析、核密度分析
    ArcMap操作随记(1)
    ArcGIS下载安装
    新生报到问题(简单的数据采集)
    ArcGIS热点分析
    学校选址问题(学校用地适宜性分析)
    ArcScene数据与Sketchup数据的交互
  • 原文地址:https://www.cnblogs.com/VictorierJwr/p/12878473.html
Copyright © 2011-2022 走看看