统计重复字母的个数

题目:字符串bbbbssdf---->b4s2df的转换

注:如果字符串是无序的,可以先排序在统计

实例代码如下:

#include<iostream>
#define MAX_LENGTH 100
using namespace std;
void ConversionCharArray(char *str,char *dest){
	int k=0;//目标数组游标
	char *pre=str;
	char *cur=str+1;
	int len=1;//重复字符个数
	while(*cur){
		if(*pre!=*cur){
			dest[k++]=*pre;
			dest[k++]=len+'0'; //数字转换为字符存储
			pre=cur;//pre位置改变
			cur=cur+1;//后移
			len=1;//重新置len长度为1
		}else{
			len++;
			cur=cur+1;//后移
		}
	}
	dest[k++]=*pre;//处理最后一种字符
	dest[k++]=len+'0';
	dest[k]='\0';//目标字符串结尾空字符
}
int main(){	
	char str[]="bbbbssdf";
	char dest[MAX_LENGTH];
	ConversionCharArray(str,dest);
	int i=0;
	char *tra=dest;
	while(*tra){
		cout<<tra[i];
		tra++;
	}
	cout<<endl;
	return 0;
}

输出结果正确:b4s2d1f1


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值