测试工程师的技能升级:LeetCode算法挑战与职业成长

简介: 这篇文章通过作者亲身体验LeetCode算法题的过程,探讨了测试工程师学习算法的重要性,并强调了算法技能对于测试职业成长的必要性。

先说LeetCode

  • 不知何时起,LeetCode在全网风靡,一道算法题无论难度都是一篇博客,作为一个IT人,刷题乐趣也无穷!!!
---摘自百度百科

力扣(LeetCode)是领扣网络旗下专注于程序员技术成长和企业技术人才服务的[品牌]。
源自美国硅谷,力扣为全球程序员提供了专业的IT技术职业化提升平台,有效帮助[程序员]
此外,力扣(LeetCode)致力于解决程序员[技术评估]、培训、职业匹配的痛点,逐步引领[互联网技术]
求职和招聘迈向[专业化] 。
  • 所以面向世贸,它属于舶来品。里面很重要的点,就是刷题,面向面试,技术不够刷题来凑,当然运气也得不错。
---摘自百度百科

力扣是一个为全球程序员提供IT技术职业化提升的平台,提供了完善的在线判题服务、学习工具、社区讨论及模拟面试功能,全方位打磨程序员职业所需的核心技能。

力扣为用户提供了多种多样的开发工具,适用于真实的日常技术开发和学习场景。其中,Playground无需设置环境,就能够帮助用户进行测试、开发、学习,甚至直接在线完成整个项目。

上正道,我的第一道LeetCode

掘金是一个帮助开发者成长的社区,是一个面向互联网技术人的内容分享平台。以年龄论:它还比较年轻!!!
题目难度:简单 
题1:整数反转
题2:最长公共前缀
题3:搜索插入的位置
  • 从测试角度一看,全是bug,别急,选个题三看看<怎样描述bug>:
    微信图片_20210726141001.jpg
定睛一看,很好理解,已知条件如下:
1、排序数组和目标值<python数组是以list类型>
2、1<=数组长度<=10**4;
3、-10**4<=元素值<=10**4;
4、数组以无重复元素的升序数组;
5、-10**4<=目标值<=10**4;
6、从示例看隐藏需求:元素值均为整型
  • 先不急忙码代码,先做测试分析
1、传入乱序数组怎么办?
2、数组有重复元素怎么办?
3、超出边界值怎么办?
4、元素不是数值怎么办?
...我的天啊,我在干嘛,不就是简单的算个题吗,按已知条件来不就行了吗?
  • 抱歉,测试的职业病犯了,挡都挡不住!
# 所以需求理解之后:传入一个在条件范围内且无重复元素的升序数组,元素、目标值也在条件范围内。
class Solution(object):
    def searchInsert(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: int
        """
        # 第一个条件至少不是空列表
        if not nums:return ""

        len1=len(nums)
        index=nums.index(target) if target in nums else nums.append(target)
        len2=len(nums)
        # 取巧,数组前后元素是否有新增
        if len2>len1:
            nums.sort() # 升序
            index=nums.index(target)
        return index

image.png

  • 再换成测试的想法实现一遍:
class Solution(object):
    def searchInsert(self, lis_num, target):
        """
        :type lis_num: List[int]
        :type target: int
        :rtype: int
        """
        # 数组长度
        length = len(lis_num)
        # 判断第一个条件,数组长度范围
        if length < 1 and length > 10 ** 4:
            return "数组长度范围错误"
        # 判断第二个条件目标值数据类型和范围
        if not isinstance(target, int) and target < -10 ** 4 and target > 10 ** 4:
            return "目标值类型或长度范围错误"
        # 遍历数组,判断第三个条件,数组元素类型及范围
        for li in lis_num:
            if not isinstance(li, int) and li < -10 ** 4 and li > 10 ** 4:
                return "数组元素类型或长度范围错误"
            # 如果不存在则加入数组
            if target not in lis_num:
                lis_num.append(target)
        # python默认升序
        lis_num.sort()
        # 获取元素索引位置
        index = lis_num.index(target)
        return index

image.png

  • 请原谅作者测试的职业病又犯了,测试下LeetCode怎么评估出执行时间和运行内容的排名,又写一遍算法实现
class Solution(object):
    def searchInsert(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: int
        """
        if not nums:return ""
        if target not in nums:
            nums.append(target)
            nums.sort()
        index=nums.index(target)
        return index

image.png

  • 从测试角度出发的实现,因为要执行更多代码,所以时间较长,如果从已知条件来讲执行时间短,但是内存消耗不相伯仲,但是差0.3M,打败的相差50%,测试冤枉得很!

总结:测试到底需不需要会算法呢?

这是一个伪命题,如果你想浑浑噩噩的测试过一生,那无所谓,反之,想更进一步,测试会算法那是必不可少的。
话说回来,不管是算法还是啥,在IT界它只不过是需求,那么是需求就要有被实现的可能,既然有可能,那么必克之!
相关文章
|
1月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
1月前
|
人工智能 自然语言处理 测试技术
让AI帮你跑用例-重复执行,不该成为测试工程师的主旋律
测试不该止步于重复执行。测吧科技推出用例自动执行智能体,通过AI理解自然语言用例,动态规划路径、自主操作工具、自动重试并生成报告,让测试工程师从“点点点”中解放,专注质量思考与创新,提升效率3倍以上,节约人力超50%,重构测试生产力。
|
3月前
|
算法 测试技术 API
从自学到实战:一位测试工程师的成长之路
在技术快速发展的今天,自动化测试已成为提升职场竞争力的关键技能。本文讲述了一位测试工程师从自学到实战的成长之路,分享他在学习UI、APP和API自动化过程中遇到的挑战,以及如何通过实际项目磨炼技术、突破瓶颈。他从最初自学的迷茫,到实战中发现问题、解决问题,再到得到导师指导,逐步掌握测试开发的核心思维,并向测试平台建设方向迈进。文章总结了他从理论到实践、从执行到思考的转变经验,强调了实战、导师指导和技术服务于业务的重要性。最后,邀请读者分享自己的技术突破故事,共同交流成长。
|
3月前
|
Prometheus 监控 Cloud Native
测试开发工程师的必备法宝:性能监控与分析工具全面指南
在软件开发高速迭代的今天,性能问题直接决定着产品质量和用户体验。作为测试开发工程师,熟练运用专业的性能监控与剖析工具,不仅能精准定位系统瓶颈,更能为优化决策提供可靠依据。本文将系统解析当前主流的性能监控与剖析工具及其应用场景。
|
4月前
|
人工智能 Java 测试技术
Java or Python?测试开发工程师如何选择合适的编程语言?
测试工程师如何选择编程语言?Java 还是 Python?多位资深专家分享建议:Python 入门简单、开发效率高,适合新手及自动化测试;Java 生态成熟,适合大型项目和平台开发。建议结合公司技术栈、个人基础及发展方向选择。长远来看,两者兼通更佳,同时关注 Go 等新兴语言。快速学习与实践才是关键。
|
7月前
|
人工智能 自然语言处理 JavaScript
测试工程师要失业?Magnitude:开源AI Agent驱动的端到端测试框架,让Web测试更智能,自动完善测试用例!
Magnitude是一个基于视觉AI代理的开源端到端测试框架,通过自然语言构建测试用例,结合推理代理和视觉代理实现智能化的Web应用测试,支持本地运行和CI/CD集成。
900 15
测试工程师要失业?Magnitude:开源AI Agent驱动的端到端测试框架,让Web测试更智能,自动完善测试用例!
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
137 0
|
9月前
|
存储 数据可视化 测试技术
一个测试工程师的实战笔记:我是如何在Postman和Apipost之间做出选择的?
优秀的API测试工具应该具备: 分层设计:既有可视化操作,也开放代码层深度定制 场景感知:自动识别加密需求推荐处理方案 协议包容:不强迫开发者为了不同协议切换工具 数据主权:允许自主选择数据存储位置
258 7
|
存储 算法 Java
leetcode算法题-有效的括号(简单)
【11月更文挑战第5天】本文介绍了 LeetCode 上“有效的括号”这道题的解法。题目要求判断一个只包含括号字符的字符串是否有效。有效字符串需满足左括号必须用相同类型的右括号闭合,并且左括号必须以正确的顺序闭合。解题思路是使用栈数据结构,遍历字符串时将左括号压入栈中,遇到右括号时检查栈顶元素是否匹配。最后根据栈是否为空来判断字符串中的括号是否有效。示例代码包括 Python 和 Java 版本。
278 4
|
存储 消息中间件 运维
架构升级的救星!流量回放自动化测试的必备指南
大家好,我是小米,一名29岁的技术宅。今天分享一个物联网领域的实用技能——流量回放自动化测试。系统重构后,测试工作量巨大,本文介绍如何通过日志收集和数据回放进行自动化测试,包括离线、实时和并行回放模式,帮助快速定位Bug,提升测试效率和系统稳定性。欢迎关注我的微信公众号“软件求生”,获取更多技术干货!
456 3

热门文章

最新文章