今天去某在线教育面试面试官让做的一道题,题目描述如下:
很多人一想可能就是两层for循环,我想了很久最后写了双重for循环…【这个代码太easy就不放了】然后面试官说知道哈希吗,由于哈希查找的时间复杂度是o(1),从哈希的角度去考虑,这中间还有一堆就不描述了,说一下怎么用哈希实现。
实现思路:
将数组中的所有的值放入hashmap的key中,value存放该值对应的下标,遍历这个hashmap,取得key,计算如果可以和这个key加起来的和为num的值,如果这个值存在,就直接返回这两个下标。遍历一次的时间复杂度为o(n),查找的时间复杂度是o(1),总体时间复杂度o(n)。
代码实现:
相关文章
猜你喜欢
- ASP.NET自助建站系统的域名绑定与解析教程 2025-06-10
- 个人服务器网站搭建:如何选择合适的服务器提供商? 2025-06-10
- ASP.NET自助建站系统中如何实现多语言支持? 2025-06-10
- 64M VPS建站:如何选择最适合的网站建设平台? 2025-06-10
- ASP.NET本地开发时常见的配置错误及解决方法? 2025-06-10