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

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

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

服務器之家 - 編程語言 - JAVA教程 - 使用游長編碼對字符串壓縮 Run Length編碼示例

使用游長編碼對字符串壓縮 Run Length編碼示例

2019-11-04 14:18java教程網 JAVA教程

這篇文章主要介紹了Run Length編碼的一個示例,大家參考使用吧

例:Helloooooo => He2l6o

 

復制代碼代碼如下:


/**
 * Run-Length編碼(游長編碼)
 * @author will
 *
 */
public class RunLengthEncoder {

 public static void main(String[] args) {  
  String input = "0";

  System.out.println("Original String Length: " + input.length());

  String encodedStr = encode(input);
  System.out.println("Encoded String: " + encodedStr);
  System.out.println("Encoded String Length: " + encodedStr.length());

  String decodedStr = decode(encodedStr);
  System.out.println("Decoded String: " + decodedStr);
 }

 /**
  * 用Run-Length算法編碼字符串
  * @param sourceStr 原始字符串
  * @return
  */
 public static String encode(String sourceStr) {
  if(sourceStr == null || sourceStr.length() <= 1) {
   return sourceStr;
  }

  int len = sourceStr.length();
  StringBuilder resultBuilder = new StringBuilder();
  for(int i = 0; i < len; i++) {
   char cur = sourceStr.charAt(i);
   int runLength = 1;
   while((i+1) < len && sourceStr.charAt(i+1) == cur) {
    i++;
    runLength++;
   }

   if(runLength > 1) {
    resultBuilder.append(runLength + "" + cur);
   }
   else {
    resultBuilder.append(cur);
   }
  }

  return resultBuilder.toString();
 }

 /**
  * 解碼Run-Length編碼的字符串
  * @param encodedStr
  * @return
  */
 public static String decode(String encodedStr) {
  if(encodedStr == null || encodedStr.length() <= 1) {
   return encodedStr;
  }

  int len = encodedStr.length();
  StringBuilder resultBuilder = new StringBuilder();
  for(int i = 0; i < len; i++) {
   char curChar = encodedStr.charAt(i);
   if(Character.isDigit(curChar)) {
    i++;
    char nextChar = encodedStr.charAt(i);
    int runLength = Integer.parseInt(curChar + "");
    for(int j = 0; j < runLength; j++) {
     resultBuilder.append(nextChar);
    }
   }
   else {
    resultBuilder.append(curChar);
   }
  }

  return resultBuilder.toString();
 }

 

}

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91免费精品国自产拍在线可以看 | 午夜精品久久久久久久2023 | 亚洲精品国产自在现线最新 | 日本高清在线播放 | 成人永久免费福利视频网站 | 国产精品高清一区二区三区 | 久久精品人人做人人爽97 | 动漫美女被褥吸奶漫画漫画 | 激情偷拍网 | 国内9lporm自拍视频区 | 九九精品成人免费国产片 | 久青草国产在线观看视频 | 日韩精品一区二区三区中文在线 | 国产自产自拍 | 成人高辣h视频一区二区在线观看 | 91大神在线精品播放 | 男人天堂资源 | 91精品天美精东蜜桃传媒免费 | 18国产精品白浆在线观看免费 | 国产 日韩 欧美 综合 | 爆操俄罗斯美女 | 毛片在线免费视频 | 日本免费在线播放 | 国产精品青青青高清在线观看 | 日本阿v在线播放 | 亚洲国产区男人本色在线观看欧美 | 99re这里只有精品视频在线观看 | 侵犯小男生免费视频网站 | 午夜国产精品视频 | 亚洲第一区欧美日韩精品 | 青青五月天 | 国产在线精品成人一区二区三区 | 日本护士xxxx视频 | tiny4k欧美极品在线 | 亚洲国产精品久久久久久网站 | ass日本乱妇ass | 男人躁女人过程 | 粗了大了 整进去好爽视频 刺激一区仑乱 | 亚洲福利二区 | 明星h文集合短篇小说 | 日产乱码卡1卡2卡三卡四在线 |