对算法的理解?应用场景?

本文探讨了算法的定义、特点,以及在前端开发中的实际应用,如虚拟DOM和diff算法。强调算法和数据结构在提高代码效率、实现业务功能(如联想搜索)中的重要性。
摘要由CSDN通过智能技术生成
一.是什么

算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制

也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出

如果一个算法有缺陷,或不适于某个问题。执行这个算法将不会解决这个问题

一个程序=算法+数据结构,数据结构是算法实现的基础,算法总要依赖某种数据结构来实现的,两者是不可分割的

因此,算法的设计和选择要同时结合数据结构,简单的说数据结构的设计就是选择存储方式,如确定问题中的信息是用数组存储还是普通的变量存储或者其他更加复杂的数据结构

针对上述,可以得出一个总结:不同的算法可能用不同的时间,空间或者效率来完成同样的效率

二.特性

关于算法的五大特性。有如下:

  • 有限性:一个算法必须保证执行有限步之后结束
  • 确切性:一个算法的每一个步骤必须有确切的定义
  • 输入:一个算法有零个或多个输入,以刻画运算对象的初始情况,所谓零个输入是指算法本身给定了初始条件
  • 可行性:算法中执行的任何计算步骤都是可以被分解为基本的可执行的操作步骤,即每个计算步骤都可以在有限时间内完成(也称之为有效性)
三,应用场景

在前端领域中,数据结构与算法无处不在,例如现在的vue或者react项目,实现虚拟dom或者fiber结构,本质就是一种数据结构,如下一个简单的虚拟DOM:

{
  type: 'div',
    props: {
      name: 'lucifer'
    },
      children: [{
        type: 'span',
        props: {},
        children: []
      }]
}

vue和react都能基础对应的数据结构实现diff算法。提高了整个框架的性能以及拓属性

 包括在前端javascript编译的时候,都会生成对应的抽象语法书ast,其本身不涉及到任何语法,因此你只要编译相应的转义规则,就可以将任何语法转义到任何语法,也是babel,postcss,prettier,typescript

除了这些框架或者工具底层用到算法与数据结构之外,日常业务无处不在,例如实现一个输入框携带联想功能,如实现一个输入框携带联想功能,如下:

 我们如果要实现这个功能,则需要使用前缀树,如下

 包括前端可能会做一些对字符串进行像是度检测,例如“每日一题”和“js每日一题”两个字符串进行像是都比较,这种情况可以通过最小编辑距离算法,如果a和b的编辑距离越小,我们认为越相似

日常在编写任何代码都需要一个良好的算法思维,选择好的算法或者数据结构,能够让整个程序效率更高。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值