数学题(找规律)-hdu-4371-Minimum palindrome
题目链接:
http://acm.hdu.edu.cn/showproblem.php?pid=4731
题目大意:
给一个n表示有n种字母(全部小写),给一个m,求一个由不超过n种字母组成的m个小写字母的串S,使得S在所有的满足要求的串中最长的回文子串长度最短。
解题思路:
显然当n>=3时肯定是abcabc这样构造。
当n=1时为aaaaaa...
当n=2时,打表可以发现规律。当m>=9时,都满足开始为aaaa,后面为以babbaa作为循环节的串。
打表截图:
压缩暴力打表代码:
char ans[25],temp[25];
int Max; int Cal(char * a,int len)
{
int res=1;
for(int i=0;i<len;i++)
{
int j;
for(j=1;i-j>=0&&i+j<len;j++)
if(a[i-j]!=a[i+j])
break;
if(j*2-1>res)
res=j*2-1;
int aa=i,bb=i+1;
while(aa>=0&&bb<len)
{
if(a[aa]!=a[bb])
break;
aa--,bb++;
}
if((i-aa)*2>res)
res=(i-aa)*2;
}
return res;
} void dfs(int cur,int len)
{
if(cur>len)
{
temp[len]='\0';
int cnt=Cal(temp,len);
if(cnt<Max)
{
strcpy(ans,temp);
Max=cnt;
}
else if(cnt==Max)
{
if(strncmp(temp,ans,len)<0)
strcpy(ans,temp);
}
return ;
}
temp[cur]='0';
dfs(cur+1,len);
temp[cur]='1';
dfs(cur+1,len);
} int main()
{
for(int i=1;i<=20;i++)
{
Max=INF;
dfs(0,i);
for(int j=0;j<i;j++)
putchar(ans[j]-'0'+'a');
putchar('\n');
} return 0;
}
代码:
#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstdlib>
#include<string>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
#include<set>
#include<stack>
#include<list>
#include<queue>
#include<ctime>
#define eps 1e-6
#define INF 0x3fffffff
#define PI acos(-1.0)
#define ll __int64
#define lson l,m,(rt<<1)
#define rson m+1,r,(rt<<1)|1
#pragma comment(linker, "/STACK:1024000000,1024000000")
using namespace std; char temp[10][10]={"","a","ab","aab","aabb","aaaba","aaabab",
"aaababb","aaababbb"};
char ba[7]="babbaa"; int main()
{
int t,n,m; scanf("%d",&t);
for(int ca=1;ca<=t;ca++)
{
scanf("%d%d",&n,&m);
printf("Case #%d: ",ca); if(m<=n)
{
for(int i=0;i<m;i++)
putchar('a'+i);
}
else
{
if(n==1)
{
for(int i=0;i<m;i++)
putchar('a');
}
else if(n>=3)
{
for(int i=0;i<m;i++)
{
int j=i%3;
putchar('a'+j);
}
}
else
{
if(m<=8)
{
printf("%s\n",temp[m]);
continue;
}
printf("aaaa");
m-=4;
int num=m/6;
for(int i=1;i<=num;i++)
printf("%s",ba);
m-=num*6;
for(int i=0;i<m;i++)
putchar(ba[i]); }
}
putchar('\n');
}
return 0;
}
数学题(找规律)-hdu-4371-Minimum palindrome的更多相关文章
- HDU 4731 Minimum palindrome (2013成都网络赛,找规律构造)
Minimum palindrome Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- HDU 4731 Minimum palindrome 打表找规律
http://acm.hdu.edu.cn/showproblem.php?pid=4731 就做了两道...也就这题还能发博客了...虽然也是水题 先暴力DFS打表找规律...发现4个一组循环节.. ...
- HDU 4731 Minimum palindrome (找规律)
M=1:aaaaaaaa…… M=2:DFS+manacher, 暴出N=1~25的最优解,找规律.N<=8的时候直接输出,N>8时,头两个字母一定是aa,剩下的以aababb循环,最后剩 ...
- hdu 1030 Delta-wave(数学题+找规律)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1030 Delta-wave Time Limit: 2000/1000 MS (Java/Others ...
- HDU 4731 Minimum palindrome 2013 ACM/ICPC 成都网络赛
传送门:http://acm.hdu.edu.cn/showproblem.php?pid=4731 题解:规律题,我们可以发现当m大于等于3时,abcabcabc……这个串的回文为1,并且字典数最小 ...
- hdu_1030(数学题+找规律)
规律就是两个数字的level差+left差+right差 代码: #include<cstdio> #include<iostream> #include<cstring ...
- HDU 5795 A Simple Nim(SG打表找规律)
SG打表找规律 HDU 5795 题目连接 #include<iostream> #include<cstdio> #include<cmath> #include ...
- hdu 3032 Nim or not Nim? (SG函数博弈+打表找规律)
Nim or not Nim? Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Sub ...
- HDU 2147 kiki's game (简单博弈,找规律)
kiki's game Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 40000/1000 K (Java/Others)Total ...
随机推荐
- Linux系统针对网卡中断的优化处理
摘要: 中断: 当网卡接收到数据包后,会触发硬中断,通知CPU来收包.硬中断是一个CPU和网卡交互的过程.这其实会消耗CPU资源.特别是在使用速度极快的万兆网卡 之后,大量的网络交互使得CPU很大一部 ...
- 如何去除List中的重复值?
今天碰到一个问题,已经有一个List<string>,里面有重复值,希望将重复值去掉,同时不能破坏现有的顺序. 感谢 http://bbs.csdn.net/topics/39024721 ...
- 常见 wifi热点的linux 驱动
小度Wifi.360Wifi Windows.linux驱动 小度wifi什么的就是一个无线网卡,当然可以自由使用,然官方却说不支持无限网卡功能… 现提供Windows平台和linux平台的驱动安装方 ...
- ubuntu KDE/GNOME vnc
- 优步北京B组(8月10日-8月16日奖励规则)
奖励政策: [优步北京B组] 定义为2015年7月20日前激活的部分司机(以优步后台数据显示为准) 滴滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机( ...
- paip.QQ音乐导出歌单总结
paip.QQ音乐导出歌单总结 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/attilax ...
- wxAui Frame Management用法
wxAui Frame Management用法:1. 总体步骤# 安装wxpython2.8.*.*后import wx.aui# 初始化一个wxAui管理框架对象mgr = wx.aui.AuiM ...
- iOS开发 使用Xcode自带的Leaks
http://www.jianshu.com/p/0837331875f0 http://www.cnblogs.com/tanzhenblog/p/5001344.html?utm_source=t ...
- Java入门基础总结(二)
判断语句 if else 如下: 1 /* 2 语法: 3 if(条件) 4 { 5 ...
- sqlplus handbook
1.直接敲sqlplus并回车就是启动SQL*PLUS,输入user及password将使用户登陆到缺省的数据库. 请输入用户名: 2.sqlplus user/password@SERVICE_NA ...