【计蒜客】两数之和

给定一个数组 numberinumber_inumberi​,找到两个数,使得他们的和为一个给定的数值 targettargettarget。

其中:number[index1]+number[index2]==targetnumber[index_1] + number[index_2]==targetnumber[index1​]+number[index2​]==target。

注意:index1index_1index1​ 必须小于 index2index_2index2​ 且不能为 000。假设每一组输入只有唯一的一组解。

例如,对于数组 [2,7,11,15][2,7,11,15][2,7,11,15] 和 target=9target=9target=9,index1index_1index1​ 的值为 111,index2index_2index2​ 的值为 222。

输入格式

第一行输入一个整数 n(1≤n≤500)n(1 \leq n \leq 500)n(1≤n≤500),接下来的两行分别输入 nnn 个整数组成的数组 numberi(0≤numberi≤1000)number_i(0 \leq number_i \leq 1000)numberi​(0≤numberi​≤1000) 和一个整数 target(0≤target≤1000)target(0 \leq target \leq 1000)target(0≤target≤1000)。

输出格式

输出一行由空格分隔的两个整数 index1index1index1 和 index2index2index2。注意,下标从 111 开始

样例输入

3
5 75 25
100

样例输出

2 3

 

python:

n = int(input())
A = input().split(" ")
A = [int(A[i]) for i in range(n)]
target = int(input())
flag = False
for i in range(n-1):
    if(A[i] == 0):
        continue
    else:
        for j in range(i+1,n):
            if(A[i]+A[j] == target):
                flag = True
                break
    if(flag == True):
        print(i+1,j+1)
        break
                

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值