一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美zoosex| 国产精品成人免费福利 | 香蕉视频久久 | 数学老师扒开腿让我爽快 | 国产日韩精品一区二区在线观看 | 暖暖中国免费观看高清完整版 | 韩国丽卡三级作品 | 草莓香蕉绿巨人丝瓜榴莲18 | 99国产高清久久久久久网站 | 国产精品99久久久 | 欧美穿高跟鞋做爰 | 91久色| 国产a在线 | 久久re热在线视频精99 | 美女在线看永久免费网址 | 高清一级做a爱免费视 | 国语自产拍在线观看7m | 久久AV国产麻豆HD真实乱 | 日本中文字幕在线观看视频 | 日本免费观看的视频在线 | sex5·性屋娱乐| fistingvideos头交尿眼 | 久久精品美女 | 亚洲欧美在线免费观看 | 国产福利在线观看第二区 | 免费看男人狂躁女人 | 17岁韩国在线观看免费1 | 成人高清网站 | 天天综合网网欲色 | 亚洲精品中文字幕久久久久久 | 亚洲视频免 | 激情视频在线播放 | 美女张开大腿让男人桶 | 五月天淫 | 大象传媒短视频网站 | 放荡的女老板bd中文字幕 | 女人肮脏的交易中文字幕未删减版 | 国产一区二区在线免费观看 | 性导航h | 国产成人亚洲精品91专区手机 | 国产成人福利美女观看视频 |