博客
关于我
JAVA 压缩字符串
阅读量:156 次
发布时间:2019-02-27

本文共 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/

你可能感兴趣的文章
mysql会对联合索性排序优化_MySQL索引优化实战
查看>>
MySQL作为服务端的配置过程与实际案例
查看>>
Mysql使用命令行备份数据
查看>>
MySQL保姆级教程(SQL语法基础篇)从小白到高手的进阶指南,收藏这一篇就够了
查看>>