在数组中查找两个数,使得它们的和正好是输入的那个数字(C语言)

 我来答
松甜恬0Je4ba
2014-03-27 · TA获得超过2.6万个赞
知道大有可为答主
回答量:7475
采纳率:100%
帮助的人:3344万
展开全部
#include <stdio.h>

int binary_search(int *a, int low, int high,int x)
{
    int mid;

    while (low <= high)
    {
        mid = low + (high - low)/2;
        if (a[mid] == x) return mid;
        else if (a[mid] < x) low = mid + 1;
        else high = mid -1;
    }
    return -1;
}
void sum(int *a,int len,int sum)
{
   for (int i = 0; i < len; ++i)
   {
    if (binary_search(a,0,len-1,sum-a[i]) != -1)
    {
        printf("%d %d\n",a[i],sum-a[i]);
        return;
    }
   }
}

int main()
{
    int a[] = {1,2,4,7,11,15};
    sum(a,sizeof(a)/sizeof(a[0]),15);
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式