码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Set与二分法效率


    stl中有set用于匹配是否存在,内部利用rbtree机制,是一种高效算法

    但在c语言环境下,stl是不能直接使用,因此需要用其他算法来代替,二分法也是一种快速排序方法,代码逻辑也比较简单。

    由于项目中,会碰到协议的筛选,例如跟进协议ID筛选,然后需要继续处理;

    此时由于前端输入是广播数据,往往大部分数据都是"不需要处理"的,如果不进行优化,此处效率的确低下.

    本来没有这篇作业的,由于测试结果并不是set效率都高于二分法的

    测试条件限制:        

    1. 每次都是拿不存在此数组的数据进行比较(最差情况下)
    2. 最大数组长度为102,然后50,25,12   (实际项目中一般以20~30居多)
    3. 测试一轮是循环1000000次,目的是容易比较结果
    4. 测试环境为windows环境,CPU能力较高,时间仅用于判断趋势
    5. 测试时间结果,每次并不一样,但总在一点范围内

    先看数据截图:

    二分法数据测试

    被测数组长度为 102

    被测数组长度为 50

    被测数组长度为 25

     被测数组长度为 12

    如果使用set

      被测数组长度为 102

     

     被测数组长度为 50

     

     被测数组长度为 25

     被测数组长度为 12

     

     再来一张对比表格

    数组长度

    set-count

    set-find

    二分

    102

    58

    58

    197

    50

    54

    55

    102

    25

    46

    49

    57

    20

    48

    48

    40

    12

    39

    41

    22

    结论:

    1. 当数组本身比较少的时候(小于20),其实还是二分法比较快;也就是说如果本身就是小数组的时候,还不如用二分法。
    2. 数组成倍增加,二分法耗时也会接近成倍增加;而set明显优化好很多
    3. set适合数组比较大,而且随着数组越大,优势越明显
    4. 可能数组本身不大,且类型为基本类型,set使用count 与find去比较是否存储,几乎没有啥变化

  • 相关阅读:
    REACT全家桶(4)----组件
    Vue3源码解读之patch
    配置nodejs的俩小脚本
    最新出炉!2022金九银十Java面试复盘,22w字
    【数据结构——单链表】本篇文章通过图文结合的方式能让你轻松的掌握单链表
    mysql存储过程
    Netty之protobuf服务端、nodejs客户端
    牛客题目——滑动窗口的最大值、矩阵最长递增路径、顺时针旋转矩阵、接雨水问题
    <深度学习基础> Batch Normalization
    Spring--AOP,代理模式,基于注解的AOP和基于XML的AOP
  • 原文地址:https://blog.csdn.net/winafa/article/details/125626737
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号