JAVA算法:回文字符串相关问题详解(回文字符串总结)

JAVA算法:回文字符串相关问题详解(回文字符串总结)JAVA算法:回文字符串相关问题详解(回文字符串总结)Q1.编写一个工具方法判断给定的字符串是否为回文字符串例如:给定一个字符串“aabbaa”,判断该字符串是否为回文字符串。算法设计如下: /* *给定一个字符串,判断该字符串是否为一个回文字符串 *start表示需要判断的起始位置 *end表示需要判断的结束位置 */ publicstatic…

大家好,又见面了,我是你们的朋友全栈君。

JAVA算法:回文字符串相关问题详解(回文字符串总结)

Q1. 编写一个工具方法判断给定的字符串是否为回文字符串

 例如:给定一个字符串“aabbaa”,判断该字符串是否为回文字符串。

算法设计如下:

	/*
	 * 给定一个字符串,判断该字符串是否为一个回文字符串
	 * start表示需要判断的起始位置
	 * end表示需要判断的结束位置
	 */

	public static boolean isPalindrome(String input, int start, int end) {
		while (start < end) {
			if (input.charAt(start++) != input.charAt(end--))
				return false;
		}
		return true;
	}

完整的测试代码如下:

package com.bean.algorithm.palindromic;

public class PalindromicUtils {

	/*
	 * 给定一个字符串,判断该字符串是否为一个回文字符串
	 * start表示需要判断的起始位置
	 * end表示需要判断的结束位置
	 */

	public static boolean isPalindrome(String input, int start, int end) {
		while (start < end) {
			if (input.charAt(start++) != input.charAt(end--))
				return false;
		}
		return true;
	}

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String str="aabbaa ";
		//String str="fafadabcbafdfdfas";
		//注意去掉字符串前后的空格
		str=str.trim();
		boolean flag=isPalindrome(str,0,str.length()-1);
		System.out.println("Flag is: "+flag);
		
	}

}

程序运行结果;

Flag is: true


Q2. 求给定字符串中的最长回文子串

输入一个字符串,求出其中最长的回文子串。

子串的含义是:在原串中连续出现的字符串片段。

在求解这个问题的时候,一定要看清楚问题。不要混淆“子串”和“子序列”的概念。“子串”是指在源字符串中连续出现的字符串片段;而“子序列”是指在源字符串中可以不连续出现的字符串片段。一个连续,一个不连续。

回文的含义是:子串从左向右看和从右向左看是相同的,例如:abba,yyxyy。 在判断时忽略所有标点符号和空格,且忽略大小写,但是输出应保持原样。
输入字符串的长度不超过5000,且占据单独一行。 应该输出最长的回文串。如果有多个,输出起始位置最靠左的一个。

例如给定字符串:fafadabcbafdfdfas

其最长回文子串为:afdfdfa

算法设计如下:

package com.bean.algorithmexec;

import java.io.FileNotFoundException;

public class LongestPalindromeString3 {

	/*
	 *  
	 * 输入一个字符串,求出其中最长的回文子串。 
	 * 子串的含义是:在原串中连续出现的字符串片段。
	 * 回文的含义是:子串从左向右看和从右向左看是相同的,例如:abba,yyxyy。 在判断时忽略所有标点符号和空格,且忽略大小写,但是输出应保持原样。
	 * 输入字符串的长度不超过5000,且占据单独一行。 应该输出最长的回文串。如果有多个,输出起始位置最靠左的一个。
	 *  
	 */

	/*
	 * 动态规划算法
	 * dp(i, j) 表示是否 s(i ... j) 能够形成一个回文字符串
	 * 当 s(i) 等于 s(j) 并且  s(i+1 ... j-1) 是一个回文字符串时 dp(i, j) 的取值为 true
	 * 当我们找到一个回文子字符串时,我们检查其是否为最长的回文字符串
	 */
	public static String longestPalindrome(String s) {
		// n表示字符串的长度
		int n = s.length();
		String res = null;
		// 定义一个dp数组
		boolean[][] dp = new boolean[n][n];
		// 外层循环控制从最后一个字符向第一个字符渐进
		for (int i = n - 1; i >= 0; i--) {
			// 内层循环控制
			for (int j = i; j < n; j++) {
				// dp数组元素
				dp[i][j] = s.charAt(i) == s.charAt(j) && (j - i < 3 || dp[i + 1][j - 1]);

				if (dp[i][j] && (res == null || j - i + 1 > res.length())) {
					res = s.substring(i, j + 1);
				}
			}
		}

		return res;
	}

	public static void main(String[] args) throws FileNotFoundException {
			// 读取输入的字符串
			String strdemo = "fafadabcbafdfdfas";
			String ANSWER = longestPalindrome(strdemo);
			System.out.println(ANSWER);
	}
}

程序运行结果:

afdfdfa

另外一种算法:

package com.bean.algorithmexec;

public class LongestPalindromeString4 {

	static void printSubStr(String str, int low, int high) {
		System.out.println(str.substring(low, high + 1));
	}


	static int longestPalSubstr(String str) {
		int maxLength = 1; 

		int start = 0;
		int len = str.length();

		int low, high;

	
		for (int i = 1; i < len; ++i) {
			
			low = i - 1;
			high = i;
			while (low >= 0 && high < len && str.charAt(low) == str.charAt(high)) {
				if (high - low + 1 > maxLength) {
					start = low;
					maxLength = high - low + 1;
				}
				--low;
				++high;
			}

		
			low = i - 1;
			high = i + 1;
			while (low >= 0 && high < len && str.charAt(low) == str.charAt(high)) {
				if (high - low + 1 > maxLength) {
					start = low;
					maxLength = high - low + 1;
				}
				--low;
				++high;
			}
		}

		System.out.print("最长回文子串为: ");
		printSubStr(str, start, start + maxLength - 1);

		return maxLength;
	}

	
	public static void main(String[] args) {
		String str = "fafadabcbafdfdfas";

		System.out.println("长度是: " + longestPalSubstr(str));

	}
}

程序运行结果为:

最长回文子串为: afdfdfa
长度是: 7


Q3. 对于给定的字符串输出所有可能的回文子串分区

例如:给定字符串 str = “bcc”

输出结果为:[“b”, “c”, “c”], [“b”, “cc”]

算法设计:

package com.bean.algorithm.palindromic;

import java.util.ArrayList;
import java.util.Deque;
import java.util.LinkedList;

public class PrintAllPalindrome {

	public static void main(String[] args) {
		String input = "abbcbba";
		//String input = "fafadabcbafdfdfas ";
		
		System.out.println("对于给定的字符串 " + input + " 的所有可能的回文分区 :");

		allPalPartitions(input);
	}

	private static void allPalPartitions(String input) {
		int n = input.length();

		// 用于存放所有回文子串( palindromic partitions)
		ArrayList<ArrayList<String>> allPart = new ArrayList<>();

		// 用于存放当前回文子串( palindromic partitions)
		Deque<String> currPart = new LinkedList<String>();

		// 递归调用方法生成所有分区部分
		allPalPartitonsUtil(allPart, currPart, 0, n, input);

		// 输出所有分区部分字符串
		for (int i = 0; i < allPart.size(); i++) {
			for (int j = 0; j < allPart.get(i).size(); j++) {
				System.out.print(allPart.get(i).get(j) + " ");
			}
			System.out.println();
		}

	}


	private static void allPalPartitonsUtil(ArrayList<ArrayList<String>> allPart, Deque<String> currPart, int start,
			int n, String input) {
		
		if (start >= n) {
			allPart.add(new ArrayList<>(currPart));
			return;
		}

		for (int i = start; i < n; i++) {

			// 如果子串  str[start..i] 是回文子串( palindrome)
			if (isPalindrome(input, start, i)) {

				currPart.addLast(input.substring(start, i + 1));

				allPalPartitonsUtil(allPart, currPart, i + 1, n, input);

				// 从当前分区中删除子串 str[start..i]
				currPart.removeLast();
			}
		}
	}

	// 判断字符串是否为回文字符串(Palindrome)的工具方法(utility function) 
	private static boolean isPalindrome(String input, int start, int i) {
		while (start < i) {
			if (input.charAt(start++) != input.charAt(i--))
				return false;
		}
		return true;
	}

}

程序运行结果:

对于给定的字符串 abbcbba 的所有可能的回文分区 :
a b b c b b a 
a b b c bb a 
a b bcb b a 
a bb c b b a 
a bb c bb a 
a bbcbb a 
abbcbba 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141891.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 国内服务器免备案访问教程是什么_国外服务器国内域名要不要备案

    国内服务器免备案访问教程是什么_国外服务器国内域名要不要备案首先我们需要准备:1.国内服务器一台2.一级域名一个3.免费免备案的CDNNodecache(百度搜索即可,可通过无限注册来一直白嫖)首先打开宝塔面板添加一个网站,然后去域名解析到你的服务器!(以获得一个源站域名)现在开始进入Nodecache进行cdn设置首先我们注册登录要创建CDN服务然后开始配置CDN服务信息(具体配置请看图)服务名称随便填加速域名就是你要访问的域名源站地址就是你的服务器ip端口跟着我填8866地区选择中国直连复制打.

    2025年10月18日
    6
  • 数据结构(1)-线性表「建议收藏」

    数据结构(1)-线性表「建议收藏」1.线性表:n个数据元素的有序集合。线性表是一种常用的数据结构。在实际应用中,线性表都是以栈、队列、字符串、数组等特殊线性表的形式来使用的。由于这些特殊线性表都具有各自的特性,因此,掌握这些特殊线性表的特性,对于数据运算的可靠性和提高操作效率都是至关重要的。  线性表是一个线性结构,它是一个含有n≥0个结点的有限序列,对于其中的结点,有且仅有一个开始结点没有前驱但有一个后继结点,有且仅有

    2022年5月18日
    34
  • CISCO产品

    CISCO产品

    2021年8月1日
    107
  • 大数据开发 岗位需要的知识——写给大数据开发初学者的话

    经常有初学者在博客和QQ问我,自己想往大数据方向发展,该学哪些技术,学习路线是什么样的,觉得大数据很火,就业很好,薪资很高。如果自己很迷茫,为了这些原因想往大数据方向发展,也可以,那么我就想问一下,你的专业是什么,对于计算机/软件,你的兴趣是什么?是计算机专业,对操作系统、硬件、网络、服务器感兴趣?是软件专业,对软件开发、编程、写代码感兴趣?还是数学、统计学专业,对数据和数字特别感兴趣

    2022年4月9日
    57
  • linux 操作系统 哪个好用,一款非常好看好用的国产Linux操作系统发行版

    linux 操作系统 哪个好用,一款非常好看好用的国产Linux操作系统发行版原标题:一款非常好看好用的国产Linux操作系统发行版之前在网上看到有网友说,国产操作系统的界面不好看,很简陋很粗糙,就像是WindowsXP的那种年代久远的操作界面一样。也有网友反驳说,国产操作系统界面友好,看起来很舒服。那么事实上是怎样的呢?到底是国产操作系统的设计还停留在人家微软的远古时代,还是部分网友对国产操作系统的认知有偏差?下面我来为大家展示一下。笔者接下来为大家展示的,是在国内做是…

    2022年5月17日
    47
  • SFM原理简介「建议收藏」

    SFM原理简介「建议收藏」StructureFromMotionSFM简介通过相机的移动来确定目标的空间和几何关系,是三维重建的一种常见方法。它与Kinect这种3D摄像头最大的不同在于,它只需要普通的RGB摄像头即可,因此成本更低廉,且受环境约束较小,在室内和室外均能使用。SFM基本原理小孔相机模型在计算机视觉中,最常用的相机模型就是小孔成像模型,它将相机的透镜组简化为一个小孔…

    2022年6月20日
    30

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号