Java实现通用组合算法

发表于:2011-12-27 09:36

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:未知    来源:51Testing软件测试网采编

  测试用例如下所示:

  1. package org.shirdrn;  
  2. import java.util.ArrayList;  
  3. import java.util.Collection;  
  4. import junit.framework.TestCase;  
  5. import org.shirdrn.util.GoodTools;  
  6. public class TestCommonSplitter extends TestCase {  
  7. private CommonSplitter splitter;  
  8. public void setSplitter(Collection container, int starCount, boolean duplicate) {  
  9. this.splitter = new CommonSplitter(container, starCount, duplicate);  
  10. }  
  11. public void testSplliter() {  
  12. Collection container = new ArrayList();  
  13. container.add("1*10**");  
  14. int starCount = 2;  
  15. boolean duplicate = true;  
  16. this.setSplitter(container, starCount, duplicate);  
  17. System.out.println(this.splitter.getFilteredContainer());  
  18. }  
  19. public void testSplliter3() {  
  20. Collection container = new ArrayList();  
  21. container.add("1*10*1300*");  
  22. int starCount = 3;  
  23. boolean duplicate = true;  
  24. this.setSplitter(container, starCount, duplicate);  
  25. System.out.println(this.splitter.getFilteredContainer());  
  26. assertEquals(35this.splitter.getFilteredContainer().size());  
  27. }  
  28. public void testNoStar() {  
  29. Collection container = new ArrayList();  
  30. container.add("3110330");  
  31. int starCount = 3;  
  32. boolean duplicate = true;  
  33. this.setSplitter(container, starCount, duplicate);  
  34. System.out.println(this.splitter.getFilteredContainer());  
  35. assertEquals(35this.splitter.getFilteredContainer().size());  
  36. }  
  37. public void testSplitter_8_310() {  
  38. // 8 场:310  
  39. String multiSeq = "310,310,310,310,310,310,310,310";  
  40. Collection container = GoodTools.getNSingleList(multiSeq);  
  41. assertEquals(6561, container.size());  
  42. int starCount = 4;  
  43. boolean duplicate = false;  
  44. this.setSplitter(container, starCount, duplicate);  
  45. assertEquals(459270this.splitter.getFilteredContainer().size());  
  46. }  
  47. }

  上述测试耗时大约2s左右。

  上述算法实现主要是针对两种条件进行实现的,即:

  第一个是完全数字字符串 ——> 带有*号的组合数字字符串;

  第二个带有*号的组合数字字符串 ——> 在该基础上继续组合得到带有*号的组合数字字符串。

  如果使用上述算法实现处理第一个条件,由于使用了列表List来记录索引,使执行速度略微低一点,比之于前面实现的不使用List列表来处理。

22/2<12
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号