LeetCode - 1. Two Sum

简介: 1. Two Sum  Problem's Link  ---------------------------------------------------------------------------- Mean:  给定一个数组nums和一个数target,求:id1和id2.

1. Two Sum 

Problem's Link

 ----------------------------------------------------------------------------

Mean: 

给定一个数组nums和一个数target,求:id1和id2. (nums[id1]+nums[id2]=target,id1和id2为数组nums两个不同的下标).

注意:nums中元素可重.

analyse:

如果nums中没有重复元素,那么可以用map做.

由于有重复元素,需要用multimap.

注意:使用map时,需要用count(key)来检测是否存在key值,否则会出现错误.

Time complexity: O(N*logN)

 

view code

/**
* -----------------------------------------------------------------
* Copyright (c) 2016 crazyacking.All rights reserved.
* -----------------------------------------------------------------
*       Author: crazyacking
*       Date  : 2015-01-29-14.24
*/
#include <queue>
#include <cstdio>
#include <set>
#include <string>
#include <stack>
#include <cmath>
#include <climits>
#include <map>
#include <cstdlib>
#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long( LL);
typedef unsigned long long( ULL);
const double eps( 1e-8);

class Solution {
public :
    vector < int > twoSum( vector < int >& nums , int target)
    {
            int cnt = 0;
            vector < int > ans;
            multimap < int , int > mp;
            for( auto p: nums)
                  mp . insert( make_pair(p , cnt ++));
            for( auto p: mp)
            {
                  if( mp . count( target -p . first) > 0)
                  {
                        multimap < int , int >:: iterator it1 , it2;
                        if((p . first == target -p . first) &&( mp . count(p . first) == 2))
                        {
                              it1 = mp . find(p . first);
                              ans . push_back(( * it1 ). second + 1);
                              mp . erase( it1);
                              it2 = mp . find(p . first);
                              ans . push_back(( * it2 ). second + 1);
                              break;
                        }
                        it1 = mp . find(p . first);
                        it2 = mp . find( target -p . first);
                        ans . push_back(( * it1 ). second + 1);
                        ans . push_back(( * it2 ). second + 1);
                        break;
                  }
            }
            sort( ans . begin (), ans . end());
            return ans;
    }
};

int main()
{
      int n;
      while( cin >>n)
      {
            vector < int > ve;
            for( int i = 0 , tmp; i <n; ++ i)
            {
                  cin >> tmp;
                  ve . push_back( tmp);
            }
            int target;
            cin >> target;
            Solution a;
            vector < int > ans = a . twoSum( ve , target);
            for( auto p : ans)
                  cout <<p << endl;
      }
      return 0;
}

 

目录
相关文章
|
存储 缓存 算法
LeetCode刷题---Two Sum(一)
LeetCode刷题---Two Sum(一)
Leetcode 4. Median of Two Sorted Arrays
题目描述很简单,就是找到两个有序数组合并后的中位数,要求时间复杂度O(log (m+n))。 如果不要去时间复杂度,很容易就想到了归并排序,归并排序的时间复杂度是O(m+n),空间复杂度也是O(m+n),不满足题目要求,其实我开始也不知道怎么做,后来看了别人的博客才知道有个二分法求两个有序数组中第k大数的方法。
44 0
|
存储 C++ Python
LeetCode刷题---Add Two Numbers(一)
LeetCode刷题---Add Two Numbers(一)
|
存储 算法 安全
LeetCode - #2 Add Two Numbers
我们社区从本期开始会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。 不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。
LeetCode - #2 Add Two Numbers
|
存储 算法 安全
LeetCode - #1 Two Sum
我们社区从本期开始会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 职业健身教练。)的 Swift 算法题题解整理为文字版以方便大家学习与阅读。 不积跬步,无以至千里;不积小流,无以成江海,Swift社区 伴你前行。
LeetCode - #1 Two Sum
LeetCode 350. Intersection of Two Arrays II
给定两个数组,编写一个函数来计算它们的交集。
80 0
LeetCode 350. Intersection of Two Arrays II
|
Python
LeetCode 349. Intersection of Two Arrays
给定两个数组,编写一个函数来计算它们的交集。
74 0
LeetCode 349. Intersection of Two Arrays
LeetCode 160. Intersection of Two Linked Lists
编写一个程序,找到两个单链表相交的起始节点。
72 0
LeetCode 160. Intersection of Two Linked Lists
LeetCode 167 Two Sum II - Input array is sorted(输入已排序数组,求其中两个数的和等于给定的数)
给定一个有序数组和一个目标值 找出数组中两个成员,两者之和为目标值,并顺序输出
93 0
LeetCode 21. 合并两个有序链表 Merge Two Sorted Lists
LeetCode 21. 合并两个有序链表 Merge Two Sorted Lists