package com.xmd.quartz.test.string; import java.util.*; /** * User: xumengdi * Date: 2019/9/9 */ public class TestTwo { public static void main(String[] args) { //迴文串有:a,a,b,b,a,a,c // aa // bb // aabbaa // abba String str = "aabbaac"; List<String> temp = new ArrayList<String>(); int begin = 0,last = 0; while(last < str.length()){ temp.add(str.substring(begin,last+1)); begin = last+1; last++; } Collections.reverse(temp); String first = ""; List<String> res = new ArrayList<>(); int count = 0; int i = 0; while(count<temp.size()){ for(i=0;i<temp.size();i++){ first = first+temp.get(i); res.add(first); } first = ""; temp = temp.subList(1,temp.size()); } List<List<String>> result = new ArrayList<>(); for(int n=0;n<res.size();n++){ String before = res.get(n); String after = new StringBuffer(before).reverse().toString(); if(before.equals(after)){ if(before.length()>1){ List<String> subList = new ArrayList<>(); subList.add(before); result.add(subList); } } } Set<List<String>> set = new HashSet<List<String>>(); for(int s =0;s<result.size();s++){ set.add(result.get(s)); } List<String> strlist = new ArrayList<>(); strlist.add("a,a,b,b,a,a,c"); set.add(strlist); System.out.println(set.toString()); } }
給定一個字符串,寫出所有該字符串的子串爲迴文串的子串
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.