数学题(找规律)-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 ...
随机推荐
- python----面向对象:1类的定义
1.python中定义类的格式如下: class className(baseClassName): def functionName(argslist): 2.定义一个person类:它有一个Nam ...
- LPC同STM32的比较
Cortex-M3是新兴起来的一种ARM7的核,而ARM7TDMI是一种传统的经典的ARM内核.我们就抛开这一切,来比较一下两则的异同. 我们就在以下平台上比较吧: STMicoelectronics ...
- QtQml 应用程序的性能考虑与建议(来自小V的翻译)
QtQml 应用程序的性能考虑与建议 原文:csdn aidear_evo QtQml应用程序的性能考虑与建议 本文翻译自Qt官网文档:http://doc.qt.io/qt-5/qtquick-pe ...
- docker 容器管理常用命令
Docker 容器管理: docker create -it centos //这样可以创建一个容器,但该容器并没有启动: create Create a new container 创建一个容器: ...
- docker 基于现有镜像修改后保存,上传私有仓库
docker:/root# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES f3cb864be528 192.168.3 ...
- Python学习笔记6-异常捕获取
#--encoding:utf-8-- try: float('abc') except Exception,e: print e try: float(1.2) except Exception,e ...
- LCP Array(思维)
LCP Array Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Tota ...
- jquery动态连接节点
<1> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://w ...
- $(this) 和 this
在使用 jQuery 时,$(this) 和 this 具体指: this :是当前 DOM 对象: $(this) 是jQuery对象: 例子: <input type="text& ...
- svn代码版本管理
1.0开发,做dev1.0的branch此时的目录结构svn://proj/ +trunk/ (不负担开发任务) +branches/ ...