LeetCode之两数之和

1、暴力解法

kotlin 复制代码
/**
     * 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target  的那 两个 整数,并返回它们的数组下标。
     * 你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。
     * 你可以按任意顺序返回答案。
     */
    fun twoSum(nums: IntArray, target: Int): IntArray {
        var firstIndex = -1
        var secondIndex = -1
        if (nums.size < 2) return intArrayOf(firstIndex, secondIndex)
        for (i in 0 until nums.size) {
            val lastValue = target - nums[i]
            firstIndex = i
            for (j in i + 1..nums.size - 1) {
                if (nums[j] == lastValue) {
                    secondIndex = j
                    return intArrayOf(firstIndex, secondIndex)
                }
            }
        }
        return intArrayOf(firstIndex, secondIndex)
    }

2、需要注意的地方

边界判断不准,导致结果出错。

break只是跳出了一层循环,导致结果出错。

3、优化方式

采用hashMap的方式

相关推荐
Kidddddult1 分钟前
力扣刷题Day 43:矩阵置零(73)
算法·leetcode·力扣
大龄Python青年2 小时前
C语言 交换算法之加减法,及溢出防范
c语言·开发语言·算法
啊我不会诶2 小时前
CF每日5题
算法
朱剑君3 小时前
排序算法——基数排序
算法·排序算法
COOCC13 小时前
PyTorch 实战:从 0 开始搭建 Transformer
人工智能·pytorch·python·深度学习·算法·机器学习·transformer
进击的小白菜4 小时前
如何高效实现「LeetCode25. K 个一组翻转链表」?Java 详细解决方案
java·数据结构·leetcode·链表
拾忆-eleven4 小时前
C++算法(19):整数类型极值,从INT_MIN原理到跨平台开发实战
数据结构·c++·算法
JK0x075 小时前
代码随想录算法训练营 Day39 动态规划Ⅶ 打家劫舍
算法·动态规划
blammmp5 小时前
算法专题四:前缀和
java·开发语言·算法
望未来无悔6 小时前
系统学习算法:动态规划(斐波那契+路径问题)
java·算法