设计一个算法移除字符串中的重复字符,并写出测试用例。

栏目: 编程工具 · 发布时间: 7年前

内容简介:设计一个算法移除字符串中的重复字符,并写出测试用例。解决思想: 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);


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

卓有成效的程序员

卓有成效的程序员

Neal Ford / 熊节 / 机械工业出版社 / 2009-3 / 45.00元

《卓有成效的程序员》就是讲述如何在开发软件的过程中变得更加高效。同时,《卓有成效的程序员》的讲述将会跨语言和操作系统:很多技巧的讲述都会伴随多种程序语言的例子,并且会跨越三种主要的操作系统,Windows(多个版本),Mac OS X以及 *-nix (Unix或者Linux)。 《卓有成效的程序员》讨论的是程序员个体的生产力,而不是团队的生产力问题,所以它不会涉及方法论(好吧,可能总会在......一起来看看 《卓有成效的程序员》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

MD5 加密
MD5 加密

MD5 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具