内容简介:设计一个算法移除字符串中的重复字符,并写出测试用例。解决思想: 1:对于每个字符,检查在一发现字符集合中是否已经存在。2:若存在,则跳过,否则加入到已发现字符集合中。
设计一个算法移除字符串中的重复字符,并写出测试用例。
解决思想: 1:对于每个字符,检查在一发现字符集合中是否已经存在。
2:若存在,则跳过,否则加入到已发现字符集合中。
1 #include<iostream> 2 3 void removeDuplicates(char *str) 4 { 5 if(str==NULL) 6 return; 7 int len=strlen(str); 8 if(len<2) 9 return; 10 int tail=1; 11 for(int i=1;i<len;++i) 12 { 13 int j; 14 for(j=0;j<tail;++j) 15 { 16 if(str[i]==str[j]) 17 break; 18 } 19 if(j==tail) 20 { 21 str[tail]=str[i]; 22 ++tail; 23 } 24 } 25 str[tail]=0; 26 printf("%s\n",str); 27 } 28 29 int main() 30 { 31 char mystr[]="abababa"; 32 removeDuplicates(mystr); 33 return 0; 34 }
测试用例:1:不含有重复字符的字符串,如“abcd”;
2: 含单一字符的字符串,如“aaaa”;
3: 空字符与空指针,如“”与NULL;
4:多个连续的字符串,如“aaabbb”;
5: 不连续重复的字符串,如“abababa”;
时间复杂度为O(n2);
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 查找一个字符串中最长不含重复字符的子字符串,计算该最长子字符串的长度
- 字符串、字符处理总结
- 高频算法面试题(字符串)leetcode 387. 字符串中的第一个唯一字符
- php删除字符串最后一个字符
- (三)C语言之字符串与字符串函数
- 算法笔记字符串处理问题H:编排字符串(2064)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Go程序设计语言
艾伦 A. A. 多诺万 / 李道兵、高博、庞向才、金鑫鑫、林齐斌 / 机械工业出版社 / 2017-5 / 79
本书由《C程序设计语言》的作者Kernighan和谷歌公司Go团队主管Alan Donovan联袂撰写,是学习Go语言程序设计的指南。本书共13章,主要内容包括:Go的基础知识、基本结构、基本数据类型、复合数据类型、函数、方法、接口、goroutine、通道、共享变量的并发性、包、go工具、测试、反射等。 本书适合作为计算机相关专业的教材,也可供Go语言爱好者阅读。一起来看看 《Go程序设计语言》 这本书的介绍吧!