美文网首页
递归在JavaScript中的应用

递归在JavaScript中的应用

作者: 洛天天 | 来源:发表于2016-08-07 15:08 被阅读0次

题目来自codewars,原题大意为,你在森林中需要一个方向的指引走出去,因为精力和食物有限,所以你要精简路径,比如路径为 ,东-西-南-北,那你就呆在原地不要动,如果路径为东--西--西--南--北,那就只往西走好了,但是这种相反方向的抵消只针对相邻,如果不相邻则不能抵消,比如路径为 北--东--南--西,那就乖乖按路径走就对了。

    任务就是写一个函数dirReduc,来实现路径的精简。输入为数组,比如:dirReduc(["NORTH", "SOUTH", "SOUTH", "EAST", "WEST", "NORTH", "WEST"] ,输出为["WEST"]。

方案:

function isOppsite(str1,str2)

{

if (str1 + str2 == "NORTHSOUTH") return 1 ;

if (str1 + str2 == "SOUTHNORTH") return 1;

if (str1 + str2 == "EASTWEST")  return 1 ;

if (str1 + str2 == "WESTEAST")  return 1 ;

return 0;

}

function dirReduc(arr){

// ...

for(var i = 0,len = arr.length ; i < len ; i ++){

if( isOppsite(arr[i],arr[i+1] )){

arr.splice(i,2);

dirReduc(arr);

}

}

return arr;

}

相关文章

  • 递归在JavaScript中的应用

    题目来自codewars,原题大意为,你在森林中需要一个方向的指引走出去,因为精力和食物有限,所以你要精简路径,比...

  • this在JavaScript中的应用

    this This是JavaScript函数的一个关键字。在全局上下文中(任意函数体外部),this指代全局对象,...

  • webpack学习(1)

    概念 webpack是现在JavaScript应用程序打包生成器。当webpack在处理程序的时候,会递归的构建依...

  • webpack常见问题

    0.1. 什么是webpack? webpack是javascript应用程序的模块打包程序。Webpack递归地...

  • JavaScript之递归

    递归基础 什么是递归?在JavaScript程序中,函数直接或间接调用自己。通过某个条件判断跳出结构,得出结果。递...

  • JavaScriptCore

    运行应用程序中的JavaScript程序,并支持在应用程序编写JavaScript。 通览 JavaScriptC...

  • webpack概念

    概念 webpack是一个现代javascript应用程序的静态模块打包器, webpack处理应用程序时他会递归...

  • webpack从配置到跑路v1

    webpack 是一个现代JavaScript应用程序的静态模块打包器。当webpack处理应用程序时,会递归构建...

  • javascript 在 photoshop 中的应用

    javascript 做为 photoshop 支持的脚本语言,让用户可以通过编写脚本来使用 photoshop ...

  • webpack概念

    webpack是一个JavaScript应用程序的静态模块打包器。当webpack处理应用程序时,它会递归地构建一...

网友评论

      本文标题:递归在JavaScript中的应用

      本文链接:https://www.haomeiwen.com/subject/jhgajttx.html