【u230】回文词
Time Limit: 1 second
Memory Limit: 128 MB
【问题描述】
CR喜欢研究回文词,有天他发现一篇文章,里面有很多回文数,这使他来了兴趣。他决定找出所有长度在n个字节以上的回文数。
在寻找回文时不用理睬那些标点符号、空格(但应该保留下来以便作为答案输出),只用考虑英文字母’A’—’Z’和’a’—’z’。
要你寻找的回文的文章是一个不超过5,000个字符的字符串。
【输入格式】
第一行为要找的回文的长度n。后面一行或几行为一个不超过5,000个字符的字符串。
【输出格式】
输出的最后一行为找到的长度大于等于n的回文词的个数。同一个回文中心只算一组回文,并且输出这组回文最长的回文。 前面一行或几行应该包括所有长度大于等于n的回文词的原文(没有除去标点符号、空格),把这些回文输出到一行或多行(如果回文中包括换行符)。 如果有多个回文长度大于等于n,全部输出所有回文。按回文中心在原文中的出现顺序依次输出。
【数据规模】
对于40%的数据: 在2000个字符以内 对于l00%的数据: 在5000个字符以内
Sample Input1
3
Confucius say:Madam,I’m Adam.
Sample Output1
Madam
Madam,I’m Adam
m Adam
3
【题目链接】:http://noi.qz5z.com/viewtask.asp?id=u230
【题解】
直接枚举就可以了;(我一直以为O(N^2)的算法会超);
枚举回文词的中心;
注意有两种情况
ABCBA
和
ABCCBA
即有的回文没有回文中心;
枚举回文的长度j;
不断判断s[i-j]和s[i+j]是否相等即可;
这题文件要一直读到底(有多行的输入、换行也要读(最后的输出读入的换行符号也要输出..)
while (scanf(“%c”,key)!=EOF) s+=c;
把字母隔离出来(全都转成小写字母判断相同即可);
【完整代码】
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <set>
#include <map>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <queue>
#include <vector>
#include <stack>
#include <string>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
void rel(LL &r)
{
r = 0;
char t = getchar();
while (!isdigit(t) && t!='-') t = getchar();
LL sign = 1;
if (t == '-')sign = -1;
while (!isdigit(t)) t = getchar();
while (isdigit(t)) r = r * 10 + t - '0', t = getchar();
r = r*sign;
}
void rei(int &r)
{
r = 0;
char t = getchar();
while (!isdigit(t)&&t!='-') t = getchar();
int sign = 1;
if (t == '-')sign = -1;
while (!isdigit(t)) t = getchar();
while (isdigit(t)) r = r * 10 + t - '0', t = getchar();
r = r*sign;
}
const int MAXN = 5500;
const int dx[5] = {0,1,-1,0,0};
const int dy[5] = {0,0,0,-1,1};
const double pi = acos(-1.0);
int n;
string s;
vector <int> a;
int lens;
void pri(int l,int r)
{
rep1(i,a[l],a[r])
cout << s[i];
puts("");
}
bool xd(char x,char y)
{
char tx = x,ty =y;
if ('A'<=x&&x<='Z')
tx='a'+x-'A';
if ('A'<=y&&y<='Z')
ty='a'+y-'A';
return tx==ty;
}
int main()
{
//freopen("F:\\rush.txt","r",stdin);
cin>>n;
getchar();
s=" ";
char key;
while (scanf("%c",&key)!=EOF)
s+=key;
lens = s.size()-1;
rep1(i,1,lens)
if (isalpha(s[i]))
a.pb(i);
int len = a.size();
int ans = 0;
rep1(i,0,len-1)
{
int j = 0;
while (i-j>=0 && i+j<=len-1 && xd(s[a[i-j]],s[a[i+j]]))
j++;
if (((j-1)*2+1)>=n)
{
pri(i-j+1,i+j-1);
ans++;
}
if (i-1>=0 && xd(s[a[i-1]],s[a[i]]))
{
int j = 1;
while (i-j>=0 && i-1+j<=len-1 && xd(s[a[i-j]],s[a[i-1+j]]))
j++;
if (((j-1)*2)>=n)
{
pri(i-j+1,i+j-2);
ans++;
}
}
}
cout << ans << endl;
return 0;
}
【u230】回文词的更多相关文章
- CSU 1328: 近似回文词
省赛的A题...现场都没什么人做...其实就一暴力水题......坑死了... 1328: 近似回文词 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 1 ...
- 字符串 - 近似回文词 --- csu 1328
近似回文词 Problem's Link:http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1328 analyse: 直接暴力枚举每一个终点,然后枚举 ...
- csuoj 1328: 近似回文词
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1328 1328: 近似回文词 Time Limit: 1 Sec Memory Limit: 1 ...
- 401 Palindromes(回文词)
Palindromes A regular palindrome is a string of numbers or letters that is the same forward as ba ...
- Vijos1327回文词【动态规划】
回文词 回文词是一种对称的字符串--也就是说,一个回文词,从左到右读和从右到左读得到的 结果是一样的.任意给定一个字符串,通过插入若干字符,都可以变成一个回文词.你的任务是写 一个程序,求出将给定字符 ...
- 回文词_KEY
回文词 (palin.pas/c/cpp) [问题描述] 回文词是一种对称的字符串--也就是说,一个回文词,从左到右读和从右到左读得的结果是一样的.任意给定一个字符串,通过插入若干字符,都可以变成一个 ...
- 回文词 (Palindromes,Uva401)
例题 3-3 回文词 (Palindromes,Uva401) 输入一个字符中,判断它是否为回文串以及镜像串.输入字符串保证不含数字0.所谓回文串,就是反转以后和原串相同,如abba和madam.所有 ...
- csu-1328 近似回文词 和 最长回文字符串
原博文地址:http://blog.csdn.net/u012773338/article/details/39857997 最长回文子串 描述:输入一个字符串,求出其中最长的回文子串.子串的含义是: ...
- CSU 1328 近似回文词【最长回文字符串(三种方法)】
输入一行文本,输出最长近似回文词连续子串.所谓近似回文词是指满足以下条件的字符串: 1. S以字母开头,字母结尾 2. a(S)和b(S)最多有2k个位置不同,其中a(S)是S删除所有非字母字符并且把 ...
随机推荐
- Datatable foeach 遍历
//1.创建 datatable DataTable dt = new DataTable("dtDemo");//可以给表创建一个名字,datatable //2.给表加个列名: ...
- WPF通用管理框架 项目客户端基础结构介绍
介绍 首先, 粗糙的展示一下目前的结构设计理念, 因为这几天一直在忙于工作, 所以跟进有些缓慢, 整体的设计是支持多种服务模式.目前只针对MSSQL做数据库接口, ORM选型则用的是微软的EF(PS: ...
- linux常用命令之lsof 、netstat、ipcs、ldd
一.lsof lsof(list open files)是一个列出当前系统打开文件的工具.在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件.每行 ...
- android 弹幕评论效果
纯粹依照自己的想法仿照b站的弹幕写的一个demo,不知道正确的姿势怎么样的. demo下载地址 首先.一条弹幕就是一个textview public abstract class Danmu exte ...
- VS Code 好用的扩展程序
1. Atom One Dark Theme.看得比较舒服的主题. 2. Beautify.格式化代码必备. 3. Bracket Pair Colorizer.不同层次的括号颜色不同,光标在括号间时 ...
- BZOJ3277: 串(后缀自动机,Parent树,Dfs序)
Description 字符串是oi界常考的问题.现在给定你n个字符串,询问每个字符串有多少子串(不包括空串)是所有n个字符串中 至少k个字符串的子串(注意包括本身). Input 第一行两个整数n, ...
- echarts如何设置背景图的颜色
公司的业务涉及到统计图的有很多,最近一直echarts里面踩各种坑,感觉应该建立一个echarts专题才对,前端的东西博大精深,无论在哪一个知识点,只要细细深究,都是别有一方天地在等待,随着需求的不同 ...
- Spring学习总结(9)——Spring AOP总结
spring IOC和AOP是Spring框架的两大核心基石,本文将对Spring AOP做一个系统的总结. 什么是AOP AOP(Aspect-Oriented Programming,面向切面编程 ...
- Android中使用HttpClient实现HTTP通信效果
HTTP通信,这一案例在操作的时候遇到N多种种问题,是前面看过几个实例里面最麻烦的一个.由于没有系统的接触过JAVA,所以出了非常多错误,也无从下手解决,这里经过对错误的检索实现了HTTP通信,以做记 ...
- js 数组操作大集合
js数组的操作 用 js有非常久了,但都没有深究过js的数组形式.偶尔用用也就是简单的string.split(char).这段时间做的一个项目.用到数组的地方非常多.自以为js高手的自己竟然无从下手 ...