回文编程

1、构造回文

给定一个字符串s,你可以从中删除一些字符,使得剩下的串是一个回文串。如何删除才能使得回文串最长呢?
输出需要删除的字符个数。

输入描述:

输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.

输出描述:

对于每组数据,输出一个整数,代表最少需要删除的字符个数。

输入例子:

abcda

google

输出例子:

2

2

思路:逆序相等,就是构成了回文。

如果不等,说明这个字符不能构成回文,删除即可

#include "stdafx.h"
#include <iostream>
#include <string>
#include <algorithm>
#include<vector>
using namespace std;

int getMaxNumber(string s1)
{
	string s2(s1);
	reverse(s2.begin(), s2.end());
	int len = s1.length();
	int tmp = 0;
	int tmp2 = 0;
	int flag = 0;
	for (int i = 0, j = 0; i < len, j < len; i++, j++){
		if (s1[i] == s2[j]){//逆序相等,说明是回文
			tmp += 1;
		}
		else{
			s1 = s1.erase(i, 1);//不等,就删除一个,剩下的是否构成回文。直到把不能构成回文的都删掉,剩下的就是能构成回文的。
			s2 = s2.erase(i, 1);
			tmp2 = max(getMaxNumber(s1), getMaxNumber(s2));
			flag = 1;//如果不是纯回文,就返回tmp2,是纯回文,就返回tmp。
			break;
		}
	}
	if (flag == 1){
		return tmp2;
	}
	else
		return tmp;

}

int main()
{
	string s;
	while (cin >> s)
	{
		cout << s.length() - getMaxNumber(s) << endl;
	}
	return 0;
}

规划组思想,参考下面链接

http://www.cnblogs.com/cnlihui/p/5567712.html

http://www.cnblogs.com/carsonzhu/p/5538531.html

时间: 2024-10-07 06:04:21

回文编程的相关文章

48.输入任意正整数,编程判断该数是否为回文数(回文数是指从左到右读与从右到左读一样,如12321)

//1.输入一个数,将其每一位分离,并保存如一个数组 //2.判断数组最后录入的一位是第几位 //3.循环判断是否满足回问数的要求 #include<iostream> using namespace std; int main() { int n,temp; int k=0; int a[20]; cout<<"please input an number: "<<endl; cin>>n; for(int i=0;i<20;i+

三个 编程题 :1. 回文 2. 将字符串t连接到字符串s的尾部

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86

Java编程判断是否是回文数

import javax.swing.JOptionPane; 自然数中还有一类数被称为回文数.回文数就是一个数的两边对称,如11,121,1221,9339,30203等等 public class CircleTest{ public static void main(String[] args){ String inputValue = JOptionPane.showInputDialog("请输入一个整数"); StringBuffer source = new String

[编程题-蘑菇街]回文串

[编程题] 回文串 给定一个字符串,问是否能通过添加一个字母将其变为回文串. 输入描述: 一行一个由小写字母构成的字符串,字符串长度小于等于10. 输出描述: 输出答案(YES\NO). 输入例子: coco 输出例子: YES #include<iostream> #include<string> using namespace std; bool f(string& s, int i) { int l = 0, r = s.size() - 1; if (l == i)

第二届战神杯线上编程挑战赛月赛第一题:回文数

题目详情: Njzy学习了回文串后联想到了回文数,他希望统计出一个区间内的全部回文数.如今给定一个闭区间[a,b],求这个区间里有多少个回文数. 比方[20,30],仅仅有一个回文数那就是22. 输入描写叙述: 输入包括多组測试数据,每组測试数据包括两个整数a,b, (0<a<=b<10^6). 输出描写叙述: 对于每组測试数据输出对应的答案. 答题说明: 输入例子: 1 10 20 30 300 400 输出例子: 9 1 10 解题思路: total[i]代表从1到i之间有多少回文数

c编程:判断10000以内的正整数哪些是回文数字。

如果有一个正整数从左.右来读都是一样的,则称为回文式数(简称回数):比如101,32123, 999都是回数.求10000以内的所有回数. 判断的思路就是,通过循环依次把m的个位,十位,百位...上的数取出来,与sum*10相加.这样得到的数sum就是m颠倒之后的数,如果两者相等,那就是回文数. while(a) { sum=sum*10+a%10; a=a/10; } 程序如下: #include<stdio.h> int main() { int i;//循环变量 int count=0;

微软编程之美——回文字符序列

描述 给定字符串,求它的回文子序列个数.回文子序列反转字符顺序后仍然与原序列相同.例如字符串aba中,回文子序列为"a", "a", "aa", "b", "aba",共5个.内容相同位置不同的子序列算不同的子序列. 限制 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 输入 第一行一个整数T,表示数据组数.之后是T组数据,每组数据为一行字符串. 输出 对于每组数据输出一行,格式为&q

编程之美资格赛 第二题 回文字符序列 dp

这是一道dp题,设置dp[i][j]代表的是从i到j之间的有多少个回文子串,dp[i][j] = dp[i][num[1]] +1+ dp[num[1]+1][j - 1]+1......+dp[num[j]][j-1] + 1 ,num[i] 代表的是与i字符相同的上一个字符的位置! 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定字符串,求它的回文子序列个数.回文子序列反转字符顺序后仍然与原序列相同.例如字符串aba中,回文子序列为"a", &quo

2015编程之美资格赛 回文子序列个数

时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定字符串,求它的回文子序列个数.回文子序列反转字符顺序后仍然与原序列相同.例如字符串aba中,回文子序列为”a”, “a”, “aa”, “b”, “aba”,共5个.内容相同位置不同的子序列算不同的子序列. 输入 第一行一个整数T,表示数据组数.之后是T组数据,每组数据为一行字符串. 输出 对于每组数据输出一行,格式为”Case #X: Y”,X代表数据编号(从1开始),Y为答案.答案对100007取模. 数据范围