两数之和 II(LeetCode)

题目

给你一个下标从 1 开始的整数数组 ,该数组已按非递减顺序排列 ,请你从数组中找出满足相加之和等于目标数 的两个数。

如果设这两个数分别是 ,则

以长度为 的整数数组 形式返回这两个整数的下标 和**。

你可以假设每个输入 只对应唯一的答案 ,而且你 不可以 重复使用相同的元素。

你所设计的解决方案必须只使用常量级的额外空间。

解题

python 复制代码
def two_sum(numbers, target):
    left = 0
    right = len(numbers) - 1

    while left < right:
        current_sum = numbers[left] + numbers[right]
        if current_sum == target:
            return [left + 1, right + 1]  # 下标从1开始
        elif current_sum < target:
            left += 1
        else:
            right -= 1


# 测试例子
numbers = [2, 7, 11, 15]
target = 9
result = two_sum(numbers, target)
print("满足条件的下标:", result)

满足条件的下标: [1, 2]

相关推荐
黛色正浓几秒前
leetCode-热题100-普通数组合集(JavaScript)
java·数据结构·算法
元亓亓亓5 分钟前
LeetCode热题100--5. 最长回文子串--中等
linux·算法·leetcode
sunywz8 分钟前
【JVM】(2)java类加载机制
java·jvm·python
千金裘换酒9 分钟前
LeetCode 环形链表+升级版环形链表
算法·leetcode·链表
小鸡吃米…9 分钟前
机器学习中的随机森林算法
算法·随机森林·机器学习
Silence_Jy11 分钟前
GPU架构
python
kwg12615 分钟前
本地搭建 OPC UA MCP 服务
python·agent·mcp
belldeep17 分钟前
python:mnist 数据集下载,parse
python·numpy·mnist
霁月中25 分钟前
[Codeforces Round 1065 (Div. 3)](A-D,F)
算法
世洋Blog28 分钟前
算法导论-分治法和合并(Merge)排序
算法