TDD+Git+Frequency Number

一、TDD是什么?

TDD是测试驱动开发(Test-Driven Development)的英文简称,是敏捷开发中的一项核心实践和技术,也是一种设计方法论。TDD的原理是在开发功能代码之前,先编写单元测试用例代码,测试代码确定需要编写什么产品代码。TDD虽是敏捷方法的核心实践,但不只适用于XP(Extreme Programming),同样可以适用于其他开发方法和过程。

二、利用TDD来解决Frequency Number问题

问题引入:

Frequency Number需求:

我想要一个nodejs小程序,
它可以帮我处理一段字符串信息,这段字符串信息是由英文单词组成,每两个单词之间有空格,
处理结果也为一段字符串,这个字符串应该每行只显示一个单词和它的数量,并且按出现频率倒序排列

example:

  • input
“it was the age of wisdom it was the age of foolishness it is”
  • output
it 3
was 2
the 2
age 2
of 2 
wisdom 1
foolishness 1
is 1

分析问题

按照Frequency Number作业的要求,利用TDD的方法可以将问题拆分为几个步骤:
1、读取—>2、划分—>3、统计—>4、排序—>5、输出


针对以上的几个小的问题再来一步一步的解决

我们先解决读取和划分的问题:

var test=function(words){
  var s=words;
  
  ss = s.split(" ");//将字符串s中每个以“ ”(空格)连接的字符串拆分成数组
var newArr = [];

for(var i =0,j = 0;i<ss.length-1;i++){
   if(newArr.indexOf(ss[i]) == -1){
    newArr.push(ss[i]);
  }
}
 
  document.write(newArr+num);
 
}
test("I am a a a a good boy");

此代码newArr.indexOf(ss[i]) == -1是判断newArr数组中是否有与ss数组中重复的,如果不重复则返回-1.所以用此代码无法进行以下统计的功能。所以改进...

得到读取、划分、统计的代码:

var test=function(words){

var res = []; 
var p;
var s=words;
ary = s.split(" ");
ary.sort();  
for(var i = 0;i<ary.length;)  
{  
   
 var count = 0;  
 for(var j=i;j<ary.length;j++)  
 {  
       
  if(ary[i] == ary[j])  
  {  
   count++;  
  }  
  }  
 res.push([ary[i],count]);  
 i+=count;  
 }  
}

这个时候就满足了上面三个要求。

再加个简单的排序功能:

for(var  i = 0 ;i<res.length;i++)  
{  
for(var j=i;j<res.length;j++)
{
if(res[j][1]>=res[i][1])
{
p=res[j];
res[j]=res[i];
res[i]=p;
}
}
}

最后再输出:

var test=function(words){
var res = []; 
var p;
var s=words;
ary = s.split(" ");
ary.sort();  
for(var i = 0;i<ary.length;)  
{  
 var count = 0;  
 for(var j=i;j<ary.length;j++)  
 {  
  if(ary[i] == ary[j])  
  {  
   count++;  

  }     
 }  
 res.push([ary[i],count]);  
 i+=count;  
 }  
//res 二维数维中保存了 值和值的重复数  
for(var  i = 0 ;i<res.length;i++)  
{  
for(var j=i;j<res.length;j++)
{
if(res[j][1]>=res[i][1])
{
p=res[j];
res[j]=res[i];
res[i]=p;
}
}
}
for(var i=0;i<res.length;i++)
{
 document.writeln(res[i][0]+" "+res[i][1]+"<br/>");  
}
}
test("it was the age of wisdom it was the age of foolishness it is");
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,891评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,179评论 25 708
  • 描述 给一整数数组, 找到数组中有多少组 不同的元素对 有相同的和, 且和为给出的 target 值, 返回对数....
    6默默Welsh阅读 828评论 0 0
  • 下午来了一位客人,说是与朋友约好谈点事,老板极为好客交代公司的茶艺师冲茶好生招待,自己便匆匆忙忙赶飞机去也。 我为...
    Iamrola阅读 263评论 0 1
  • 河虾怎么做好吃?虾营养丰富,且其肉质松软,易消化,对身体虚弱以及病后需要调养的人是极好的食物,今天小编教大家河虾的...
    沉睡的熊猫阅读 374评论 0 1