JavaScript 求两数之和

发布于 2022-09-17 21:26:43 字数 1374 浏览 201 评论 0

问题描述:给定一个数组,数组里面有两个数,他们的和是 target,求这两个数在数组中的位置。

思路:

  1. a + b = target
  2. 已知 target
  3. 求 a 和 b
function solution(nums, target) {
  for (let i = 0; i < nums.length; i++) {
    let a = nums[i]
    for (let j = i + 1; j < nums.length; j++) {
      let b = nums[j]
      if (b === target - a) {
        console.log(i, j)
      }
    }
  }
}
solution([1, 2, 3, 4], 5)

分析:

  1. 传入 [1, 2, 3, 4]
  2. 1 和 2、3、4 对比是否等于 target
  3. 2 和 3、4 对比是否等于 target
  4. 3 和 4 对比是否等于 target

注意:自己不要和自己对比,就是 a 不能和b相等,因为他是不同的两个数字。

两数之和三数之和都可以这么算

function solution(list, target) {
  let result = []
  for (let i = 0; i < list.length; i++) {
    for (let j = i + 1; j < list.length; j++) {
      let a = list[i];
      let b = list[j];
      if (a + b === target) {
        result.push([a, b])
      }
    }
  }
  return result
}

function solution(list, target) {
  let result = []
  for (let i = 0; i < list.length; i++) {
    for (let j = i + 1; j < list.length; j++) {
      for (let k = j + 1; k < list.length; k++) {
        let a = list[i]
        let b = list[j]
        let c = list[k]
        if (a + b + c === target) {
          result.push([a, b, c])
        }
      }
    }
  }
  return result
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

つ低調成傷

暂无简介

文章
评论
27 人气
更多

推荐作者

櫻之舞

文章 0 评论 0

弥枳

文章 0 评论 0

m2429

文章 0 评论 0

野却迷人

文章 0 评论 0

我怀念的。

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文