华为上机练习题:压缩字符串

题目:

通过键盘输入一串小写字母(a~z)组成的字符串。请编写一个字符串压缩程序,将字符串中连续出席的重复字母进行压缩,并输出压缩后的字符串。

压缩规则:
1、仅压缩连续重复出现的字符。比如字符串"abcbc"由于无连续重复字符,压缩后的字符串还是"abcbc"。
2、压缩字段的格式为"字符重复的次数+字符"。例如:字符串"xxxyyyyyyz"压缩后就成为"3x6yz"。

要求实现函数:

void stringZip(const char *pInputStr, long lInputLen, char *pOutputStr);

【输入】 pInputStr:  输入字符串
           lInputLen:  输入字符串长度
【输出】 pOutputStr: 输出字符串,空间已经开辟好,与输入字符串等长;

【注意】只需要完成该函数功能算法,中间不需要有任何IO的输入输出

示例

输入:“cccddecc”   输出:“3c2de2c”
输入:“adef”     输出:“adef”
输入:“pppppppp” 输出:“8p”

分析: 这里字符压缩就是判断相同字符的个数, 然后字符带个数前缀, 所以我们可以为字符计数,然后再重新拼接起来

返回栏目页:http://www.bianceng.cnhttp://www.bianceng.cn/Programming/sjjg/

这里我想到了两种办法,

1:是建立两个list,一个存储字符, 一个是存储字符的个数, 然后再根据这两个list来重新组合字符串;

2:直接在计数的过程中组合字符串

这里我选择是第二种思路, 感觉会写少点代码,偷一下懒咯,呵呵!

代码如下:

package com.wenj.test;

/*
 * @author wenj91-PC
 *
 */

public class TestStringZip {

    public static void main(String args[]){
        String strIn = "pppppppp";
        TestStringZip ts = new TestStringZip();
        System.out.println(ts.stringZip(strIn));
    }

    public String stringZip(String strIn){
        String strTemp = strIn;
        char[] strC = strTemp.toCharArray();

        String temp = "";//这里用StringBuffer比较合适,不过个人懒的折腾,读者的话注意下就好
        int count = 0;
        char preChar = strC[0];
        for(int i=0; i< strC.length; i++){
            char cTemp = strC[i];
            if(cTemp == preChar){//判断字符是否与之前字符相同
                count++;
            }else{
                if(count>1){
                    temp += count;
                }
                count = 1;
                temp += preChar;
                preChar = strC[i];
            }
            if(i==strC.length -1){//判断是否到末端
                if(count>1){
                    temp += count;
                }
                temp += strC[i];
            }
        }

        return temp;
    }
}

作者:csdn博客 zlw420123

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索string
, 字符串
, count
, 输入
, 字符
, ts不连续
, 输出
输出连续字符串
,以便于您获取更多的相关知识。

时间: 2025-01-21 08:57:10

华为上机练习题:压缩字符串的相关文章

[华为上机练习题]7.删除字符串中出现次数最少的字符

题目 描述: 实现删除字符串中出现次数最少的字符,若多个字符出现次数一样,则都删除.输出删除这些单词后的字符串,字符串中其它字符保持原来的顺序. 题目类别: 字符串 难度: 中级 运行时间限制: 10Sec 内存限制: 128MByte 阶段: 入职前练习 输入: 字符串只包含小写英文字母, 不考虑非法输入,输入的字符串长度小于等于20个字节. 输出: 删除字符串中出现次数最少的字符后的字符串. 样例输入: abcdd 样例输出: dd 代码 /*------------------------

华为上机练习题:按位取反操作

题目: 求指定位取反后的结果(用异或来进行指定位数的取反) *   输入:0x1234 3 *   输出:0x123c 分析:从网上看到这道题发现蛮有意思的, 记得当时学C语言的时候就有过这种的操作,只不过时间久了就有些健忘, 经过努力追忆后终于想起些些, 现在做出如下总结: *   AND--> & --> AND指令主要用于使操作数若干位不变, 而使某些位为'0'的场合 *   OR --> | --> OR 指令主要用于使操作数若干位不变, 而使某些位为'1'的场合

刷华为上机题库时遇到的一道编程题

问题描述 刷华为上机题库时遇到的一道编程题 题目的要求是输入一个字符串,对字符串做如下变化1:按照A-Z的顺序条换顺序,不管字母的大小写.如Type变换为epTy2:同一个英文字母的大小写同时存在时,按照输入顺序排列.如输入:BabA?输出:aABb3:非英文字母的其它字符保持原来的位置.输入:By?e?输出:Be?y #include ""iostream""#include ""string""using namespac

php压缩和解压缩字符串的方法

 本文实例讲述了php压缩和解压缩字符串的方法.分享给大家供大家参考.具体如下: 下面php代码通过gzcompress和gzuncompress压缩和解压缩字符串,可以设定压缩级别 $str = 'Hello I am a very very very very long string'; $compressed = gzcompress($str, 9);//压缩级别为9 $uncompressed = gzuncompress($compressed); echo $str, "n&quo

华为上机测试题,我只得了50分,为什么?

问题描述 华为上机测试题,我只得了50分,为什么? #define _CRT_SECURE_NO_WARNINGS#include #include #include void main(){ char str[1024]; int num[1024] = {0}; scanf(""%s"" str); for (int i = 0; i < strlen(str); i++) //判断是否除了字母以外还有其他字符如果有则删去{ while (str[i]&l

php压缩和解压缩字符串的方法_php技巧

本文实例讲述了php压缩和解压缩字符串的方法.分享给大家供大家参考.具体如下: 下面php代码通过gzcompress和gzuncompress压缩和解压缩字符串,可以设定压缩级别 $str = 'Hello I am a very very very very long string'; $compressed = gzcompress($str, 9);//压缩级别为9 $uncompressed = gzuncompress($compressed); echo $str, "\n&quo

压缩字符串

/*压缩字符串 输入只含A-Z的字符串 不超过1000个字母 将连续相同字母压缩为重复次数+字母 例 输入 ABBCCC 输出 A2B3C */ #include <stdio.h> int main() { int i,count; char tch,str[1005];//存储字符串最长1000个字符 while(gets(str))//输入字符 { count = 1; tch = str[0];//取出str[0] for(i=1; str[i] != '\0' ;++i)//str[

gzip压缩字符串

gzip压缩字符串 的使用是减轻服务器负载,服务器中的这个功能就将网页内容压缩后传输到来访的电脑浏览器中显示出来.一般对纯文本内容可压缩到原大小的40%.这样传输就快了,效果就是你点击网址后会很快的显示出来.当然这也会增加服务器的负载. static string compressstring(string input)     {         string retvalue = string.empty;         if (!string.isnullorempty(input))

Android实现压缩字符串的方法示例

前言 Android端可以对字符串进行压缩,我们在进行大量简单文本传输时,可以先压缩字符串再发送.接收端接收后再解压.也可以将字符串压缩后存入数据库中,下面话不多说了,来一起看看详细的介绍吧. 使用到的类库 GZIPOutputStream 代码示例 import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.util.zip.