博客
关于我
9.统计回文
阅读量:122 次
发布时间:2019-02-27

本文共 1052 字,大约阅读时间需要 3 分钟。

题目描述

“回文串”是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串。花花非常喜欢这种拥有对称美的回文串,生日的时候她得到两个礼物分别是字符串A和字符串B。现在她非常好奇有没有办法将字符串B插入字符串A使产生的字符串是一个回文串。你接受花花的请求,帮助她寻找有多少种插入办法可以使新串是一个回文串。如果字符串B插入的位置不同就考虑为不一样的办法。

例如:

A = “aba”,B = “b”。这里有4种把B插入A的办法:

* 在A的第一个字母之前: "baba" 不是回文

* 在第一个字母‘a’之后: "abba" 是回文

* 在字母‘b’之后: "abba" 是回文

* 在第二个字母'a'之后 "abab" 不是回文

所以满足条件的答案为2

输入描述:

每组输入数据共两行。

第一行为字符串A

第二行为字符串B

字符串长度均小于100且只包含小写字母

输出描述:

输出一个数字,表示把字符串B插入字符串A之后构成一个回文串的方法数

示例1

输入

aba

b

输出

2

 

 

解题思路

暴力求解

遍历str1,将str2 insert进str1的每个位置,判断是否回文,

是就count++

不能str1.insert(i,str2),这样str1就改变了,判断下一个位置就不对了

所以每次使用str1拷贝构造一个str

然后str.insert(i,str2),再判断

 

 

 

#include
#include
using namespace std;bool IsCircle(const string&s){ int begin = 0, end = s.size() - 1; while (begin < end) { if (s[begin] != s[end]) return false; begin++; end--; } return true;}int main(){ string str1, str2; getline(cin, str1); getline(cin, str2); int count = 0; for (int i = 0; i <= str1.size(); i++) { string str = str1; str.insert(i, str2); if (IsCircle(str)) count++; } cout << count << endl; return 0;}

 

转载地址:http://jpbb.baihongyu.com/

你可能感兴趣的文章
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>
Metasploit CGI网关接口渗透测试实战
查看>>
Metasploit Web服务器渗透测试实战
查看>>
MFC模态对话框和非模态对话框
查看>>
Moment.js常见用法总结
查看>>
MongoDB出现Error parsing command line: unrecognised option ‘--fork‘ 的解决方法
查看>>
mxGraph改变图形大小重置overlay位置
查看>>
MongoDB可视化客户端管理工具之NoSQLbooster4mongo
查看>>
Mongodb学习总结(1)——常用NoSql数据库比较
查看>>
MongoDB学习笔记(8)--索引及优化索引
查看>>
mongodb定时备份数据库
查看>>
mppt算法详解-ChatGPT4o作答
查看>>
mpvue的使用(一)必要的开发环境
查看>>
MQ 重复消费如何解决?
查看>>
mqtt broker服务端
查看>>
MQTT 保留消息
查看>>
MQTT 持久会话与 Clean Session 详解
查看>>