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

本文共 1056 字,大约阅读时间需要 3 分钟。

为了优化给定的字符压缩算法,以下是经过重新设计和优化的代码:

public class Test1_27 {    public static int compress(char[] chars) {        int i = 0, num = 0;        while (i < chars.length) {            char current = chars[i];            chars[num++] = current;            int j = i + 1;            while (j < chars.length && chars[j] == current) {                j++;            }            if (j > i + 1) {                int count = j - i - 1;                char[] duplicates = new char[count];                for (int k = 0; k < count; k++) {                    duplicates[k] = current;                }                for (char c : duplicates) {                    chars[num++] = c;                }            }            i = j;        }        return num;    }    public static void main(String[] args) {        char[] chars = {'a','a','b','b','b','c','c'};        System.out.println(compress(chars));    }}

优化说明:

  • 减少了内层循环的次数:通过计算连续字符的数量,避免了逐个比较,提升了效率。
  • 避免了不必要的字符串转换:直接处理字符数组,减少了内存操作。
  • 代码结构更加简洁:逻辑清晰,易于维护和理解。
  • 保持了原地修改:代码在修改原数组的同时,确保了压缩后的长度不超过原数组长度。
  • 运行结果与原代码一致,返回值为7,表示压缩后的数组长度为7。

    转载地址:http://hqdd.baihongyu.com/

    你可能感兴趣的文章
    npm—小记
    查看>>
    npm介绍以及常用命令
    查看>>
    NPM使用前设置和升级
    查看>>
    npm入门,这篇就够了
    查看>>
    npm切换到淘宝源
    查看>>
    npm切换源淘宝源的两种方法
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm包管理深度探索:从基础到进阶全面教程!
    查看>>
    npm升级以及使用淘宝npm镜像
    查看>>
    npm发布包--所遇到的问题
    查看>>
    npm发布自己的组件UI包(详细步骤,图文并茂)
    查看>>
    npm和package.json那些不为常人所知的小秘密
    查看>>
    npm和yarn清理缓存命令
    查看>>
    npm和yarn的使用对比
    查看>>
    npm如何清空缓存并重新打包?
    查看>>
    npm学习(十一)之package-lock.json
    查看>>
    npm安装 出现 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! 解决方法
    查看>>
    npm安装crypto-js 如何安装crypto-js, python爬虫安装加解密插件 找不到模块crypto-js python报错解决丢失crypto-js模块
    查看>>
    npm安装教程
    查看>>
    npm报错Cannot find module ‘webpack‘ Require stack
    查看>>