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的方式

相关推荐
无极低码3 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发3 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre4 小时前
22 括号生成
算法·深度优先
努力也学不会java5 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎5 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan6 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
智者知已应修善业6 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
khddvbe7 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
C羊驼7 小时前
C语言:两天打鱼,三天晒网
c语言·经验分享·笔记·算法·青少年编程