解题思路:见https://blog.csdn.net/a769973411/article/details/80400792
本人转载并改为java
参考代码:
package dotcpp.字符串;
import java.util.HashSet;
import java.util.Scanner;
public class 切开字符串 {
static int length=100001;
//判断是否为回文串
public static boolean echoSubstr(String str)
{
for(int i =0;i<str.length()/2;i++)
{
if (str.charAt(i)!=str.charAt(str.length()-i-1))
return false;
}
return true;
}
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
int n=scanner.nextInt() ;
String str,temp =" ";
str=scanner.next();
int[] echo =new int[length];//用于存储正回文子串的个数
int []notEcho=new int[length];//用于存储非正回文子串的个数
HashSet<String> e=new HashSet<>();
HashSet<String> ne=new HashSet<>();
//求正回文的个数
for (int i =0; i<n;i++)
{
for(int j=i;j>=0;j-=2)//注意这里为j-=2
{
int t= i-j+1;
temp=str.substring(j,j+t);
//判断是否是正回文子串,若是则插入集合,
//最后通过获取集合的size就可知去掉重复后的非正回文子串个数
boolean flag =echoSubstr(temp);
if(flag)e.add(temp);
}
echo[i]=e.size();
}
//求非正文子串
for (int i=n-1;i>=0;i--)
{
for(int j=i;j<n;j++)
{
//判断是否是正回文子串
boolean flag=false;
int t=j-i+1;
temp=str.substring(i,t+i);
//计算非正回文要先判断它是否是正回文子串
//因此将子串在正回文子串的集合中找是最节省资源的
if(temp.length()%2==1)
if(e.contains(temp))
flag=true;
if(!flag)ne.add(temp);
}
notEcho[i]=ne.size();
}
int result=0;
//求出最大值
for(int i=1;i<n;i++)
result=Math.max(result,echo[i-1]*notEcho[i]);
System.out.println(result);
}
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复