java-字符串压缩

作者: Ferrari1001 | 来源:发表于2018-03-23 09:58 被阅读16次
题目:

将字符串 aaabcdda (可以从控制台接收)编程实现将其转换为 3a1b1c2d1a。

算法思想:

遍历一遍字符串,力求时间复杂度为O(n),可用空间换时间。

代码实现:
Scanner s = new Scanner(System.in);  
String str = s.nextLine();  
StringBuffer result = new StringBuffer();  
// 字符串长度  
int count = str.length();  
// 取第一个字符  
char word1 = str.charAt(0);  
// 连续字符的个数  
int sum = 1;  
for (int i = 1; i < count; i++) {  
    // 循环取字符  
    char word2 = str.charAt(i);  
    // 把前一个字符和当前字符比较  
    if (word1 == word2) {  
        // 相同的字符 个数加1  
        sum++;  
        continue;  
    }  
    // 拼接字符  
    result.append(sum).append(word1);  
    // 当前字符变为前一个字符  
    word1 = word2;  
    // 个数清零  
    sum = 1;  
}  
// 加上最后一个字符及个数,并打印输出  
System.out.println("字符串压缩后:" + result.append(sum).append(word1));
注意要点:

    区分next()与nextLine()的区别:
【1】next(): 当方法遇见第一个字符为有效字符(非空格、换行字符)时,开始扫描,当遇见第一个分割符或结束符(空格或换行符)时结束扫描。反之第一个字符非有效字符,next()方法会自动将其之后的字符去掉。简单地说,next()方法返回的是来自此扫描器的下一个完整标记,完整标记的前后是与分隔模式匹配的输入信息,所以next方法不能得到带空格的字符串。
【2】nextLine():方法的结束符是Enter键,即nextLine()方法返回的是Enter键之前的所有字符,它是可以得到带空格的字符串的。

相关文章

  • java-字符串压缩

    题目: 将字符串 aaabcdda (可以从控制台接收)编程实现将其转换为 3a1b1c2d1a。 算法思想: 遍...

  • 1394-字符串压缩

    字符串压缩 题目 字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串aabc...

  • Java- 字符串和文本 I/O

    Java- 字符串和文本 I/O 字符串是封装在 String 类中的对象。要创建一个字符串,可以使用11构造方...

  • Hello Java

    目录 Java-基础(1/6) Java-对象(2/6) Java-核心库类 上(3/6) Java-核心库类下(...

  • LeetCode | 面试题 01.06. 字符串压缩【Pyth

    LeetCode 面试题 01.06. 字符串压缩【Easy】【Python】【双指针】 问题 力扣 字符串压缩。...

  • Java字符串压缩

    java 压缩字符串 如果源字符串长度小于64,压缩后的字符会比源字符串长。例如:str.length()=32c...

  • 2020-03-16 刷题1(字符串)

    01.06 字符串压缩 标签:字符串,内存题目其实很简单,用模拟法模拟字符串的压缩过程即可。但是我提交了三次,因为...

  • LeetCode 面试题 01.06. 字符串压缩

    题目 字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串aabcccccaa...

  • 面试题 01.06. 字符串压缩

    题目 字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串aabcccccaa...

  • 字符串压缩

    字符串压缩。利用字符重复出现的次数,编写一种方法,实现基本的字符串压缩功能。比如,字符串aabcccccaaa会变...

网友评论

本文标题:java-字符串压缩

本文链接:https://www.haomeiwen.com/subject/vputcftx.html