题5:字符串的压缩

2023-10-27

题目:

利用字符重复出现的次数,编写一个方法,实现基本的字符串压缩功能。
比如,字符串“aabcccccaaa”经压缩会变成“a2b1c5a3”。若压缩后的字符串没有变短,则返回原先的字符串。给定一个string iniString为待压缩的串(长度小于等于10000),
保证串内字符均由大小写英文字母组成,返回一个string,为所求的压缩后或未变化的串。测试样例
"aabcccccaaa"返回:"a2b1c5a3"
思路:

StringBuilder的用法

package 字符串问题;

public class case05_字符串压缩 {
    public static void main(String[] args) {
        String res=zipString("aaaccbbbbb");
        System.out.println(res);
    }

    private static String zipString(String scr) {
        int n=scr.length();
        int last=0;//记录上一个字符
        int count=0;
        StringBuilder sb=new StringBuilder();//用来记录压缩后的字符串
        for(int i=0;i<n;i++){
            char c=scr.charAt(i);
            if(sb.length()==0){
                sb.append(c);//处理第一个字符
                count++;
            }else{
                if(last==c){
                    count++;//和上一个字符相同
                }else{
                    sb.append(count).append(c);
                    count=1;//count重置为1,当前字符
                }
            }
            last=c;
        }

        //考虑最后一个字符
        if(count>=1){
            sb.append(count);
        }
        //比较新字符串和原字符串的长度
        if (sb.length() > scr.length()) {
            return scr;
        }
        return sb.toString();
    }

}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

题5:字符串的压缩 的相关文章

随机推荐

  • 自控重温1

    自控第一章 1 基本概念 1 自动控制 2 自动控制相关历史 2 自控 要素 1 系统描述 这里主要是讲解对于同一个线性系统的不同描述方式 而不是教你如何对系统进行建模 2 控制方法 如何施加外作用实现控制 控制信号 偏差 控制器 3 被控
  • 深圳二手房房价分析及预测

    分析目标 通过处理后的房价数据 筛选对房价有显著影响的特征变量 确定特征变量 建立深圳房价预测模型并对假设情景进行模拟 数据预处理 import pandas as pd import os file path D Python数据分析与挖
  • 外排序 归并排序 超级详细 拜托点赞

    外排序 就是比如说你在文件中你有很大的数组 你无法一起加载到内存中 只能一部分一部分的加载带内存中 然后对它进行排序 他的思想就是 我先分为几份 然后对每一份先排序 排完序后我再进行归并排序 具体步骤程序都标注明白了 请看程序注释就可以 拿
  • 字符串查找增强:findstr

    在文件中寻找字符串 FINDSTR B E L R S I X V N M O F file C string G file D dir list A color attributes OFF LINE strings drive path
  • cnn中的超参数参数设置_了解更快的r cnn配置参数

    cnn中的超参数参数设置 When I first started creating the Faster R CNN model using TensorFlow Object Detection API I couldn t find
  • jq移除某个元素样式

    执行 示例 select removeCss color select removeCss color border width function fn removeCss function options var type typeof
  • 关于git-u、--set-upstream和--set-upstream-to参数的理解

    1 git branch 既可以使用 set upstream又可以使用 set upstream to 但是前者已经被弃用 用法 git branch set upstream to origin mybranch1 mybranch1
  • 设计模式之责任链模式(Chain)

    设计模式之责任链模式 Chain 本篇为 https github com iluwatar java design patterns tree master chain 阅读笔记 意图 避免请求发送者与接收者耦合在一起 让多个对象都有可能
  • 【Cocos谁学谁会】定制属于自己的脚本模板

    版权申明 本文原创首发于以下网站 您可以自由转载 但必须加入完整的版权声明 博客园 https www cnblogs com MogooStudio csdn博客 https blog csdn net nmjkl001 知乎 https
  • 【C# in Unity】取绝对值;position变换注意点;协程注意点

    1 C 中取绝对值 Math Abs value C 中取绝对值的函数 weixin 30715523的博客 CSDN博客 2 position变换注意点 不可以这样写 content transform position x x 正确写法
  • Android Studio中会自动添加@org.jetbrains.annotations.Nullable 的解决办法

    在Activity中重写onCreate等方法时 输入完onCreate后直接回车导入 会自动引入如下代码 Override protected void onCreate Nullable org jetbrains annotation
  • Python蓝桥杯 基础练习 A+B问题

    A B map int input split print A B input 从键盘输入数字 split 未带参数时 将字符串以空格进行分割 map function iterator 对可迭代对象iterator进行迭代使用functi
  • Ubuntu下查看CUDA和CUDNN版本的方法

    cuda 版本 cat usr local cuda version txt cudnn 版本 cat usr local cuda include cudnn h grep CUDNN MAJOR A 2 这个结果就表示我的CUDA版本为
  • task3:西瓜书第四章(1)

    本次是阅读西瓜书第四章 以下为笔者是在阅读第四章决策树时一些之前不曾关注地方的补充 1 实际决策树学习算法是基于启发式算法 如贪婪算法 寻求在每个节点上的局部最优决策 这样的算法思想决定了在执行过程中不能保证返回全局最优决策树 例如ID3算
  • 英特尔® 硬件加速执行管理器安装指南 — Microsoft Windows*

    介绍 本文将指导您安装英特尔 硬件加速执行管理器 英特尔 HAXM 这是一款可以使用英特尔 虚拟化技术 VT 加快 Android 开发速度的硬件辅助虚拟化引擎 管理程序 前提条件 英特尔 HAXM 要求首先安装 Android SDK 版
  • 几行代码搞定Android底部导航栏

    底部导航栏的实现也不难 就是下边是几个Tab切换 上边一般是一个FrameLayout 然后FrameLayout中切换fragment 网上有不少关于Android底部导航栏的文章 不过好像都只是关于下边Tab切的 没有实现Tab与fra
  • Hexo搭建博客教程-基于Butterfly主题

    title Hexo搭建博客教程 tags Hexo 博客教程 categories Hexo keywords Hexo 博客教程 description Hexo搭建博客 以及主题butterfly中一些常规配置 cover https
  • sqlite3交叉编译

    1 交叉编译sqllite3可以先从官网下载最新最新的源码进行编译 sqlite3下载sqlite3有两种版本的源代码 sqlite amalgamation 3420000 zip这种是将所有的操作放到sqlite3中进行使用的 虽然官方
  • synchronized 的原理

    文章目录 前言 通过一系列的问题 了解synchronized 总结 前言 synchronized 是一个关键字 在多线程中 为了同步代码块 或者同步方法就会使用到 在面试的过程中 也是非常常见的 所以很有必要掌握 通过一系列的问题 了解
  • 题5:字符串的压缩

    题目 利用字符重复出现的次数 编写一个方法 实现基本的字符串压缩功能 比如 字符串 aabcccccaaa 经压缩会变成 a2b1c5a3 若压缩后的字符串没有变短 则返回原先的字符串 给定一个string iniString为待压缩的串