计蒜客题目 两数之和

给定一个数组 number_i,找到两个数,使得他们的和为一个给定的数值 target

其中:number[index_1] + number[index_2]==target。

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

例如,对于数组 [2,7,11,15] 和 target=9,index_1 的值为 1,index_2 的值为 2。

输入格式

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

输出格式

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

样例输入

3
5 75 25
100

样例输出

2 3
#include<stdio.h>

int main()
{
    int n;
    scanf("%d",&n);
    int a[n];
    for(int i=0;i<n;i++)    scanf("%d",&a[i]);
    int sum;
    scanf("%d",&sum);
    for(int i=0;i<n;i++){
        for(int j=i+1;j<n;j++){
            if((a[i]+a[j])==sum){
                printf("%d %d",i+1,j+1);
                return 0;
            }
        }
    }
}

解题思路:用暴力破解了,标签是排序,应该可以用排序相关的内容解答出来的,问答区有人使用了hash的方法,没有看懂。

解题思路更新:可以先把输入的数组排序,之后从最小的和最大的开始相加,如果两数的和>target,则找最大的左边一个数,如果两数的和<target,则找最小的右边一个数,直到得到的和等于target为止。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值