在开发过程中难免会碰到省市区级联的操作,一般后端人员是不愿意将中文储存在数据库的。

由于应用页面较多,我们在通过区域Code写查字典函数时应该注意函数的 时间复杂度空间复杂度

如果用三层for循环遍历省市区列表,很容易就把函数的复杂度堆上立方阶或者指数阶。

addressFilter(res) {
  var shippingAddress = []
  let province, city, area
  for (province of cityList) {
    if (res.provinceCode && res.provinceCode === province.code) {
      shippingAddress.push(province.name)
      for (city of province.children) {
        if (res.cityCode && res.cityCode === city.code) {
        shippingAddress.push(city.name)
          if (res.areaCode && res.areaCode) {
            for (area of city.children) {
              if (res.areaCode === area.code) {
                shippingAddress.push(area.name)
                break
  }
            }
          } else break
          break
        }
      }
      break
    }
  }
  res.shippingAddress = shippingAddress.join(' / ')
  console.log('shippingAddress', res.shippingAddress) // '输出: shippingddress福建省/厦门市/思明区'
  return res
}

u1s1,虽然是应急方法我也被自己恶心到了。为了痛彻前非,趁现在闲下来,我决定把这段代码改了。

当初不使用  map( )  而使用  for···of  的第一个原因是 map( ) 有返回值,这个可以通过使用  filter( )  来解决,第二个原因是 map ( ) 和 filter( ) 不能  break  ,这个就很重要了。

我们生活中查字典时都是查到想要的就合上,没有终止语句的函数即使查到了想要的单词仍然会继续查完整本字典再合上,这无非大大增加了运算时间。

map( )方法

语法

array.map(function(currentValue,index,arr), thisValue)

参数说明

参数 描述
function(currentValue, index,arr) 必须。函数,数组中的每个元素都会执行这个函数
函数参数:

参数 描述
currentValue 必须。当前元素的值
index 可选。当前元素的索引值
arr 可选。当前元素属于的数组对象
thisValue 可选。对象作为该执行回调时使用,传递给函数,用作 "this" 的值。
如果省略了 thisValue,或者传入 null、undefined,那么回调函数的 this 为全局对象。

filter( )方法

语法

array.filter(function(currentValue,index,arr), thisValue)

参数说明

参数 描述
function(currentValue, index,arr) 必须。函数,数组中的每个元素都会执行这个函数
函数参数:

参数 描述
currentValue 必须。当前元素的值
index 可选。当前元素的索引值
arr 可选。当前元素属于的数组对象
thisValue 可选。对象作为该执行回调时使用,传递给函数,用作 "this" 的值。
如果省略了 thisValue ,"this" 的值为 "undefined"

map( ) 和 filter( )的区别

map( ) 方法当条件不符合时仍会返回undefined,而 filter( ) 方法是返回一个新的数组,将符合条件的item推入这个数组。

但它们都有同一个缺点就是必需遍历完全才算执行结束,可以理解成它们是等同于数组长度个数的小的函数,break只能终止其中一个,所以是无法终止整个方法的。

由此可知,它们的应用场景跟VUE的computed计算属性相似,并且在数据量较为庞大时(不含非常庞大)执行效率大幅优于for循环,呈反抛物线方程轨迹

递归函数

在有规律的js事件中,可以使用递归函数通过动态改变函数的实参调用本身,就可以对结构相同的树结构进行同样的处理,亦或是如以下代码这样遍历查询想要的结果。

searchAddress(codeArr){
  var res = []   function item(codeArr,cityJson){
    if(codeArr.length){
      const a = cityJson.filter(item=>{
        return item.code === codeArr[0]
      })
      console.log('searchAddress',a)
      res.push(a[0].name)
      codeArr.shift()
      if(codeArr.length){
        item(codeArr,a[0].children)
      }
    }
  }
  item(codeArr, cityList)
  console.log('xxxxxxxxxxxxxres:' ,res)
  return res
},

深度优先搜索(DFS & 递归)

深度优先搜索(DFS),言简意骸就是有子查子,否则查兄弟,下图访问顺序应为: A  →  B  →  C  →  D  →  E  →  H  →  I  →  J  →  F  →  G  。

  • 如果条件相匹配,将它的子树传给函数做实参再执行递归函数
  • 如果条件不匹配,通过索引拿到它的下一个兄弟结点,再次执行
/* 递归省市区json */
addressFun(inputArr) {
  var outputArr = []
  let index = 0
  let status = false
  function dfs(node) {
    if(status) {
      index = 0
      status = !status
    }
    if (node[index] && node[index].code === inputArr[0]) {
      outputArr.push(node[index].name)
      status = !status
      inputArr.shift()
      if(inputArr.length) {
        dfs(node[index].children)
      } else {
        return
      }
    } else if (node[index]) {
      index++
      dfs(node)
    } else {
      return
    }
  }
  dfs(cityList)
  return outputArr.join(' / ')
}

- END -

JS002. map( ) 和 filter( ) 的区别和实际应用场景(递归函数、深度优先搜索DFS)的更多相关文章

  1. for..of和for..in和map、filter等循环区别

    1.for in遍历的是数组的索引(即键名),而for of遍历的是数组元素值. for in遍历比较适合遍历对象,不太适合数组,有可能遍历出来的不按照顺序 遍历数组 ,,,,,] for (var ...

  2. python3高阶函数:map(),reduce(),filter()的区别

    转载请注明出处:https://www.cnblogs.com/shapeL/p/9057152.html 1.map():遍历序列,对序列中每个元素进行操作,最终获取新的序列 print(list( ...

  3. lodash 集合处理方法 map和filter区别

    <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...

  4. Python:map()、reduce()、filter()的区别

    文章转于:https://blog.csdn.net/goupper1991/article/details/49803355 原文博主:https://blog.csdn.net/goupper19 ...

  5. forEach、map、filter、reduce的区别

    1.相同点: 都会循环遍历数组中的每一项: map().forEach()和filter()方法里每次执行匿名函数都支持3个参数,参数分别是:当前元素.当前元素的索引.当前元素所属的数组: 匿名函数中 ...

  6. Spark RDD/Core 编程 API入门系列之map、filter、textFile、cache、对Job输出结果进行升和降序、union、groupByKey、join、reduce、lookup(一)

    1.以本地模式实战map和filter 2.以集群模式实战textFile和cache 3.对Job输出结果进行升和降序 4.union 5.groupByKey 6.join 7.reduce 8. ...

  7. map和flatmap的区别+理解、学习与使用 Java 中的 Optional

    转自:map和flatmap的区别 对于stream,   两者的输入都是stream的每一个元素,map的输出对应一个元素,必然是一个元素(null也是要返回),flatmap是0或者多个元素(为n ...

  8. python的map,filter,reduce学习

    python2,python3中map,filter,reduce区别: 1,在python2 中,map,filter,reduce函数是直接输出结果. 2,在python3中做了些修改,输出前需要 ...

  9. 函数与函数式编程(生成器 && 列表解析 && map函数 && filter函数)-(四)

    在学习python的过程中,无意中看到了函数式编程.在了解的过程中,明白了函数与函数式的区别,函数式编程的几种方式. 函数定义:函数是逻辑结构化和过程化的一种编程方法. 过程定义:过程就是简单特殊没有 ...

随机推荐

  1. css伪类(:before和:after)

    :before和:after的作用就是在指定的元素内容(而不是元素本身)之前或者之后插入一个包含content属性指定内容的行内元素,最基本的用法如下: #example{    width:300p ...

  2. USB 3.0 开发要点

    最近在公司里安排了我一个新的任务,那就是USB3.0的研发.对于我之前都是做ARM+LINUX和单片机软件研发的来说,虽然之前都是做驱动程序和应用程序,但是没有做与USB 相关的开发,毕竟这是第一次. ...

  3. SortCompare.time的反射版本

    "Algorithms" by Robert Sedgewick, p256, SortCompare.time(): public static double time(Stri ...

  4. Lab: 2FA bypass using a brute-force attack:暴力破解双重验证靶场复盘(困难级别)

    靶场内容: This lab's two-factor authentication is vulnerable to brute-forcing. You have already obtained ...

  5. SQL注入的那些面试题总结

    一.知识储备类 1.SQL与NoSQL的区别? SQL:关系型数据库 NoSQL:非关系型数据库 存储方式:SQL具有特定的结构表,NoSQL存储方式灵活 性能:NoSQL较优于SQL 数据类型:SQ ...

  6. VMware上安装的Ubuntu不显示全屏解决方法

    花费了好一会才把电脑上的Vmware装上,把Ubuntu装到虚拟机上,谁知道Ubuntu不显示全屏,我调了分辨率,奈何Ubuntu里面固定的分辨率没有跟我电脑匹配的,然后开始寻找解决方法,在网上找了很 ...

  7. Docker搭建网页数据库管理-Adminer

    为什么Adminer比phpMyAdmin更好? 官网介绍: 用Adminer替换phpMyAdmin,您将获得一个简洁的用户界面,对MySQL功能的更好支持,更高的性能和更高的安全性.请参阅详细比较 ...

  8. 1、Task的优势

    1.Task的优势 ThreadPool相比Thread来说具备了很多优势,但是ThreadPool却又存在一些使用上的不方便.比如: ◆ ThreadPool不支持线程的取消.完成.失败通知等交互性 ...

  9. 一 &#183; 路由事件的三种方式/策略(冒泡 直接 隧道)

    WPF中的路由事件是沿着VisualTree传递的,作用是用来调用应用程序的元素树上的各种监听器上的处理程序. (1)冒泡,这种事件处理方式是从源元素向上级流过去,直到到达根节点即顶层节点,一般为最外 ...

  10. PsSetCreateProcessNotifyRoutineEx 创建回调函数

    转载自http://blog.csdn.net/yushiqiang1688/article/details/5209597 最近要做一个进程监控的程序,功能很简单,就是创建和退出进程的时候,能触发我 ...