本文共 782 字,大约阅读时间需要 2 分钟。
要求:给定一组字符,使用原地算法将其压缩。压缩后的长度必须始终小于或等于原数组长度。数组的每个元素应该是长度为 1 的字符(不是 int 整数类型)。在完成原地修改输入数组后,返回数组的新长度。
具体代码如下:
public class Test1_27 { public static int compress(char[] chars) { int i = 0, j, num = 0; while(i < chars.length) { chars[num] = chars[i]; num++; j = i + 1; while(j < chars.length && chars[i] == chars[j]) j++; if(j - i > 1){ for (char c : String.valueOf(j - i).toCharArray()) { chars[num] = c; num++; } } i = j; } return num; } public static void main(String[] args) { char[] chars = {'a','a','b','b','b','c','c'}; System.out.println(compress(chars)); }}
运行结果示例:
转载地址:http://hqdd.baihongyu.com/