设串 T 采用堆式存储,设计一个算法,用统计串的形式给出串 T 中字符连续 出现的次数,例如‘aaabbaddddffc’的统计串为‘a3_b2_a1_d4_f2_c1’。

设串 T 采用堆式存储,设计一个算法,用统计串的形式给出串 T 中字符连续
出现的次数,例如‘aaabbaddddffc’的统计串为‘a3_b2_a1_d4_f2_c1’。

#include<iostream>
#include<stdio.h>
#include<stdlib.h>

using namespace std;
#define Ok 1
#define Error 0
typedef int Status;

typedef struct {
 char *ch;
 int length;
}HString;

Status InitString(HString &T);
int lenth(char *chars);
Status StrAssign(HString &T,char *chars);
void StrPrint(HString T);
void StrWrite(HString &S,char c);
HString Tongji(HString &T);


 Status InitString(HString &T){
  T.ch=NULL;
  T.length=0;
  return Ok;
 }
 int lenth(char *chars){
  int i=0;
  for(i;chars[i];i++);
  return i;
 }
 
 Status StrAssign(HString &T,char *chars){
  int i,len=lenth(chars);
  if(T.ch)
   free(T.ch);
  T.ch=(char*)malloc(len*sizeof(char));
  if(!T.ch)
   exit(Error);
  for(i=0;i<len;i++)
   T.ch[i]=chars[i];
  T.length=len;
  return Ok; 
 }
 
 
 void StrPrint(HString T){
  int i=0;
  while(i<T.length){
   cout<<T.ch[i];
   i++;
  }
  cout<<endl;
 }
 
 
 void StrWrite(HString &S,char c){
  S.ch=(char*)realloc(S.ch,(S.length+1)*sizeof(char));
  if(!S.ch){
   exit(Error);
  }
  S.ch[S.length]=c;
  S.length++;
 }
 
 HString Tongji(HString &T){
  HString S;
  InitString(S);
  int i,j,k;
  char ch='_';
  for(i=0;i<T.length;i=j){
   StrWrite(S,T.ch[i]);   
   j=i+1;
   char count='1';
   while(T.ch[i]==T.ch[j]){
    count=count+1;
    j++;
   }
   if(count>0){
    //count=(char)count;
    StrWrite(S,count);
   }
   StrWrite(S,ch);
   
  }
  return S;
 }
 
 int main(){
  int i=0;
  HString T,S;
  char chars[100];
  printf("请输入:\n");
  gets(chars);
  InitString(T);
  StrAssign(T,chars);
  StrPrint(T);
  S=Tongji(T);
  StrPrint(S);
 }
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值