希望你喜欢测试代码
#include <string.h>
#include <stdio.h>
void rep2end(char *string) {
char *s, *p, *e, *stop;
char c;
s = string;
e = s+strlen(string)-1; /* find end of string */
stop = e; /* place to stop processing */
while (stop > s){
c = *s; /* char to look for */
while(*(s+1) == c){ /* repeated char */
for(p = s+1; *p ; p++){ /* shuffle left to overwrite current pos *s */
*(p-1) = *p;
}
*e = c; /* set end char to be the repeat we just found */
stop--; /* bump the stop position left to prevent reprocessing */
}
s++;
}
}
main () {
char *in[]={"aabbccefghi", "uglyfruit", "highbbbbchair"};
char *out[]={"abcefghiabc", "uglyfruit", "highbchairbbb"};
char string[100];
int i;
for (i=0; i<3; i++) {
strcpy(string, in[i]);
rep2end(string);
if (!strcmp(string,out[i])) {
printf("ok\n");
}else {
printf("fail %s should be %s\n", string, out[i]);
}
}
return 0;
}