首页 > 其他 > 详细

一个数组中找到满足和为sum的两个数

时间:2014-06-21 07:37:52      阅读:346      评论:0      收藏:0      [点我收藏+]

如果考虑hashmap直接O(n)的速度,

如果不行,就先排序,两头指针很好推理,关键是

a[beg] +a[end]>sum,意思就是说a[end]太大了,最小的数的都不满足,所以排除a[end]

绝知此事要躬行

#include<iostream>
#include<algorithm>
using namespace std;

bool find(int *a,int sum,int len,int &ans1,int &ans2)
{
    int *beg=a;
    int *end=a+len-1;
    while(beg<end)
    {
        if(*beg+*end==sum)
        {
            ans1=*beg;
            ans2=*end;
            return true;
        }
        else if(*beg+*end>sum)

        {
            end--;

       
       
        }
        else
        {
            beg++;
       
        }
   
   
    }


    return false;
   


}
int main()
{
    int a[]={2,3,4,-10,34,23,23,-2,34};
    sort(a,a+sizeof(a)/sizeof(int));
    int ans1;
    int ans2;
    if(find(a,32,sizeof(a)/sizeof(int),ans1,ans2))
    {
        cout<<ans1<<endl;
        cout<<ans2<<endl;
    }
    else
    {
        cout<<"你所找的树没找到"<<endl;
    }
   system("pause");

    return 0;
}

一个数组中找到满足和为sum的两个数,布布扣,bubuko.com

一个数组中找到满足和为sum的两个数

原文:http://www.cnblogs.com/hansongjiang/p/3795364.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!