手有些生了。

题目:

通过键盘输入一串小写字母(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”

 /*
* by feifei435
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h> void stringZip(const char *pInputStr, long lInputLen, char *pOutputStr)
{
int i = ;
int same_begin = ;
int same_end = ;
char last_char = ;
while (i <= (lInputLen - ))
{
last_char = pInputStr[i];
if (pInputStr[i+] == last_char)
{
if(same_end == )
{
same_begin =i;
same_end = i+;
}
else
{
same_end++;
}
}
else
{
if(same_end != )//结束连续
{
pOutputStr[strlen(pOutputStr)] = pInputStr[same_begin];
itoa((same_end - same_begin + ), &pOutputStr[strlen(pOutputStr)], );
same_begin = ;
same_end = ;
}
else
{
pOutputStr[strlen(pOutputStr)] = pInputStr[i];
}
}
i++;
}
} int main()
{
char str [] = {};
char strZip[] = {};
printf("Input the str to be compressed:\n");
scanf("%s",str);
stringZip(str, strlen(str), strZip);
printf("%s\n",strZip); return ;
}

最新文章

  1. ifconfig: command not found(CentOS专版,其他的可以参考)
  2. [LeetCode] Customers Who Never Order 从未下单订购的顾客
  3. Oracle SQL的硬解析和软解析
  4. MP3光标移动
  5. 第三次作业——K米评测
  6. Windows下配置OpenGL环境
  7. HDU1016 Prime Ring Problem(DFS回溯)
  8. CSS引入方式的区别详解
  9. [JSOI2008] 完美的对称
  10. #!---&gt;hashbang技术
  11. 分享: 利用Readability解决网页正文提取问题
  12. 【C++基础之十一】虚函数的用法
  13. javascript数组去重算法-----2
  14. grails的controller和action那点事---远程调试groovy代码
  15. Java Spring MVC项目搭建(二)——项目配置
  16. HDU 5783 Divide the Sequence (训练题002 B)
  17. LeetCode &amp; Q66-Plus One-Easy
  18. SpringBoot 分布式session
  19. Python cmp() 函数
  20. 开源流媒体服务器SRS学习笔记(3) - HTTPCallback实现安全认证

热门文章

  1. hdu 3661 Assignments(水题的解法)
  2. C#学习笔记:泛型委托Action&lt;T&gt;和Fun&lt;TResult&gt;
  3. call,apply,bind方法的总结
  4. C# 面向对象之概念理解
  5. HDU 3507 Print Article(斜率优化DP)
  6. NuGet学习笔记——初识NuGet及快速安装使用
  7. Session过期,跳出iframe等框架
  8. lintcode 中等题:majority number III主元素III
  9. Mysql数据库int(1)和tinyint(1)的区别&amp;&amp;扩展阅读
  10. 非常实用的PHP代码片段推荐