博客
关于我
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/

    你可能感兴趣的文章
    Nginx的Rewrite正则表达式,匹配非某单词
    查看>>
    Nginx的使用总结(一)
    查看>>
    Nginx的是什么?干什么用的?
    查看>>
    Nginx访问控制_登陆权限的控制(http_auth_basic_module)
    查看>>
    nginx负载均衡的五种算法
    查看>>
    Nginx配置ssl实现https
    查看>>
    Nginx配置TCP代理指南
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    NI笔试——大数加法
    查看>>
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    Nmap扫描教程之Nmap基础知识
    查看>>
    Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
    查看>>