码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode[170]Two Sum III - Data structure design

时间:2015-02-10 15:17:36      阅读:235      评论:0      收藏:0      [点我收藏+]

标签:

Design and implement a TwoSum class. It should support the following operations: add and find.

add - Add the number to an internal data structure.
find - Find if there exists any pair of numbers which sum is equal to the value.

For example,

add(1); add(3); add(5);
find(4) -> true
find(7) -> false
class TwoSum 
{
private:
    map<int,int> fmap;
public:
    void add(int x)
    {
        if(!fmap.count(x))fmap[x]=1;
        else fmap[x]++;
    }
    bool find(int target)
    {
        for (map<int,int>::iterator iter=fmap.begin();iter!=fmap.end();iter++)
        {
            int i=iter->first;
            if(fmap.count(target-i))
            {
                if(i!=target-i)return true;
                else if(fmap[i]>=2)return true;
            }
        }
        return false;
    }
};

 



leetcode[170]Two Sum III - Data structure design

标签:

原文地址:http://www.cnblogs.com/Vae98Scilence/p/4283762.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!