激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Java版本的回文字算法(java版本)

Java版本的回文字算法(java版本)

2020-06-20 11:41高殿華 JAVA教程

本文給大家分享一段java代碼關于回文字算法的實例代碼,代碼簡單易懂,需要的朋友一起看看吧

廢話不多說了,直接給大家貼代碼了,具體代碼如下所述:

?
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
package com.gdh.backtext;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
public class BackText {
String text;
public BackText() {
  super();
  this.text = null;
}
public BackText(String text) {
  super();
  this.text = text;
}
public boolean isBackText(){
  for(int i=0,j=text.length()-i-1;i<=j;i++,j--){
    if( text.charAt(i) != text.charAt(j) ){
      return false;
    }
  }
  return true;
}
public Map<Character,Integer> countString(){
  Map<Character,Integer> map=new HashMap<>();
  int count=0;
  String temp=new String();
  for(int i=0;i< text.length();i++){
    if ( temp.indexOf(text.charAt(i), 0) < 0){
      temp+=text.charAt(i);
    }
  }
  map.clear();
  for(int i=0;i< temp.length();i++){
    if(!map.containsKey(temp.charAt(i))){
      for(int j=0;j< text.length();j++){
        if(text.charAt(j) == temp.charAt(i) ){
          count++;
        }
      }
      map.put(temp.charAt(i), count);
      count=0;
    }
  }
  //循環打印
  for(Entry<Character,Integer> item:map.entrySet()){
    System.out.println("字符:" + item.getKey() + " 值:" + item.getValue());
  }
  return map;
}
public String convert(){
  int checksum = 0;
  int itemcount=0;
  Map<Character,Integer> map=countString();
  for(Entry<Character,Integer> item:map.entrySet()){
  checksum+=item.getValue();
  if( item.getValue() %2 != 0)
    itemcount++;
  }
  if( itemcount > 1 ){
    System.out.println("該字符串不能轉換為回文字");
    return null;
  }
  StringBuffer temp=new StringBuffer(text);//線程安全
  //StringBuilder temp=new StringBuilder();//線程非安全
  int begIdx=0;
  int endIdx=checksum-1;
  Character key=null;
  boolean flag=false;
  for(Entry<Character,Integer> item:map.entrySet()){
  if( checksum % 2 ==0 ){
  for(int i=0;i<item.getValue()/2;i++){
    temp.setCharAt(begIdx++, item.getKey());
    temp.setCharAt(endIdx--, item.getKey());
  }
    }else{
      if(item.getValue()%2==0 ){
        for(int i=0;i<item.getValue()/2;i++){
          temp.setCharAt(begIdx++, item.getKey());
          temp.setCharAt(endIdx--, item.getKey());
        }
      }else{
        key=item.getKey();
        flag=true;
        continue;
      }
    }
  }
  if(flag)
  {
    for(int i=0;i<map.get(key);i++){
      temp.setCharAt(begIdx++, key);
    }
  }
  return temp.toString();
}
  public static void main(String[] args) {
    BackText bt=new BackText("1122334455667788990");
    if( !bt.isBackText() )
      System.out.println("該字符串不是回文字");
    else
      System.out.println("該字符串是回文字");
    String dest=new String();
    System.out.println("開始轉換...");
    dest=bt.convert( ) ;
    System.out.print("轉換后的結果為:");
    System.out.println(dest);
  }
}

以上所述是小編給大家介紹的Java版本的回文字算法(java版本),希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

原文鏈接:http://www.cnblogs.com/gaodianhua/archive/2016/10/01/5925488.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚州综合一区 | 国产精品久久久久久久久久三级 | 日本中文一级片 | 91精品国产91久久久 | 欧美国产精品久久 | 天天夜干| 一级免费在线 | 久久综合久久综合久久综合 | 日韩欧美综合在线 | 亚洲精品久久久久久下一站 | 黄色一级电影网 | 欧美人的天堂一区二区三区 | 久久久久国产精品久久久久 | 欧美精品一区二区三区在线 | 午夜视频在线免费播放 | 亚洲成人福利网站 | 国产午夜精品久久久久婷 | 性大片性大片免费 | 色婷婷久久久久久 | 91成人免费在线观看 | 亚洲精品aaaaa | 亚洲网站免费 | 久久免费视频精品 | 久久久久久精 | 成人午夜一区二区 | 黄色免费高清网站 | 草草视频免费观看 | 99精品视频久久精品视频 | 久久久久久久九九九九 | 国产91对白叫床清晰播放 | 视频二区国产 | 国产黄色网 | 国产91对白叫床清晰播放 | 毛片网站网址 | 成人午夜激情网 | 精品成人免费一区二区在线播放 | 欧美日韩大片在线观看 | 中国美女一级黄色大片 | 精品亚洲视频在线观看 | 亚洲影视在线观看 | 亚洲福利视频52 |