题意:有n个只包含两个字母的字符串, 要求构造一个m*m的字母矩阵, 使得矩阵的每行每列都不包含所给的字符串, m要尽量大,

如果大于20的话构造20*20的矩阵就行了。

析:开始吧,并没有读对题意,后来才看懂什么意思,然后主要思想就是如果有环,那么一定是可以构造成20*20的,只要环一直重复就好,如果没有环,

那么就要找最长的链,然后矩阵长宽就是 (max+1)/2,然后和上面一样构造就好。

代码如下:

#pragma comment(linker, "/STACK:1024000000,1024000000")
#include <cstdio>
#include <string>
#include <cstdlib>
#include <cmath>
#include <iostream>
#include <cstring>
#include <set>
#include <queue>
#include <algorithm>
#include <vector>
#include <map>
#include <cctype>
#include <cmath>
#include <stack>
#include <tr1/unordered_map>
#define freopenr freopen("in.txt", "r", stdin)
#define freopenw freopen("out.txt", "w", stdout)
using namespace std;
using namespace std :: tr1; typedef long long LL;
typedef pair<int, int> P;
const int INF = 0x3f3f3f3f;
const double inf = 0x3f3f3f3f3f3f;
const LL LNF = 0x3f3f3f3f3f3f;
const double PI = acos(-1.0);
const double eps = 1e-8;
const int maxn = 26 + 5;
const int mod = 1e9 + 7;
const int N = 1e6 + 5;
const int dr[] = {-1, 0, 1, 0};
const int dc[] = {0, 1, 0, -1};
const char *Hex[] = {"0000", "0001", "0010", "0011", "0100", "0101", "0110", "0111", "1000", "1001", "1010", "1011", "1100", "1101", "1110", "1111"};
inline LL gcd(LL a, LL b){ return b == 0 ? a : gcd(b, a%b); }
int n, m;
const int mon[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
const int monn[] = {0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
inline int Min(int a, int b){ return a < b ? a : b; }
inline int Max(int a, int b){ return a > b ? a : b; }
inline LL Min(LL a, LL b){ return a < b ? a : b; }
inline LL Max(LL a, LL b){ return a > b ? a : b; }
inline bool is_in(int r, int c){
return r >= 0 && r < n && c >= 0 && c < m;
}
int G[maxn][maxn];
char s[5];
int ans[maxn], a[maxn];
bool vis[maxn];
int cnt; bool dfs(int u, int num){
bool ok = false;
for(int i = 0; i < 26; ++i){
if(G[u][i]){
a[num] = i;
if(vis[i]){
cnt = num;
return true;
}
else{
vis[i] = true;
if(dfs(i, num+1)) return true;
vis[i] = false;
}
ok = true;
}
}
if(cnt < num && ok){
cnt = num;
memcpy(ans, a, sizeof ans);
}
return false;
} int main(){
int T; cin >> T;
while(T--){
scanf("%d", &n);
memset(G, -1, sizeof G);
for(int i = 0; i < n; ++i){
scanf("%s", s);
G[s[0]-'a'][s[1]-'a'] = 0;
} int anss = 0;cnt = 0;
for(int i = 0; i < 26; ++i){
memset(vis, false, sizeof vis);
vis[i] = true;
a[0] = i;
if(dfs(i, 1)){
bool ok = false;
int id = 0;
for(int j = 0; j < cnt; ++j)
if(ok) ans[id++] = a[j];
else if(a[j] == a[cnt]){ ans[id++] = a[j]; ok = true; }
anss = id;
break;
}
} if(anss){
for(int i = 0; i < 20; ++i){
for(int j = 0; j < 20; ++j)
printf("%c", ans[(j+i)%anss]+'a');
printf("\n");
}
}
else{
int x = (cnt+2)/2;
for(int i = 0; i < x; ++i){
for(int j = 0; j < x; ++j)
printf("%c", ans[i+j]+'a');
printf("\n");
}
} }
return 0;
}

最新文章

  1. css样式
  2. Python之import
  3. C#-WinForm-布局-Anchor-锁定布局、Dock-填充布局、工具箱中的&lt;容器&gt;
  4. meeting room I &amp; II
  5. JAVA-Semaphore信号灯-可实现维护自身线程访问数
  6. 建模算法(一)&mdash;&mdash;线性规划
  7. 【NOIP2012】国王游戏
  8. ajax连接池和XMLHttpRequest
  9. Python异常记录
  10. Java实现的 线程池
  11. PHP - 多维数组
  12. simple_list_item_1 和simple_list_item_2有什么区别???
  13. Java:文件字符流和字节流的输入和输出
  14. 编写程序,将来自文件中的行保存在一个vector&lt;string&gt;,然后使用一个istringstream 从vector中读取数据,每次读一个单词
  15. HTML+CSS之盒子模型
  16. 关于使用JPA中@Query注解传递表名/视图名参数的问题
  17. Debian 安装配置(包括kdevelop)
  18. [HDU5968]异或密码
  19. BZOJ 3878 【AHOI2014】 奇怪的计算器
  20. OraOLEDB.Oracle找不到驱动问题

热门文章

  1. js如何获取table或者ul中鼠标点的行号和内容
  2. python 怎么启动一个外部命令程序, 并且不阻塞当前进程
  3. CentOS安装Openfire服务
  4. Machine Learning—Online Learning
  5. c程序设计语言第一章2
  6. MySQL远程访问时非常慢的解决方案
  7. Qt Quick之StackView具体解释(1)
  8. VS2013带来的&amp;quot;新特性&amp;quot;
  9. jk_proxy实现apache+tomcat负载均衡
  10. ajax的异步操作及页面重定向跳转