leetcode 249 250 set和map的简单用法

leetcode249,利用了STL中的set

class Solution {
public:
    vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
        set<int> n1(nums1.begin(),nums1.end());
        set<int> n2;
        for(int i=0;i<nums2.size();i++)
        {
            if(n1.find(nums2[i])!=n1.end())
            {
                n2.insert(nums2[i]);
            }
        }

        return vector<int> results(n2.begin(),n2.end());
    }
};

思路:set中的元素不重复,利用这一点方便进行最后的插入操作而不用去重。实际上第一个set<int> n1是没有必要的,可以直接vector来查找,但是用set的效率会更高。

下面给出用vector和库里面的find实现的方式:

 1 class Solution {
 2 public:
 3     vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
 4
 5 set<int> n2;
 6
 7         for(int i=0;i<nums2.size();i++)
 8         {
 9             auto it=nums1.end();
10             if((it=find(nums1.begin(),nums1.end(),nums2[i]))!=nums1.end())
11             {
12                 n2.insert(nums2[i]);
13             }
14         }
15
16         return vector<int> (n2.begin(),n2.end());
17     }
18
19 };

vector实现

虽然每次创建一个迭代器会耗费内存,总体来说少了一个map会比较折中。

leetcode 250,利用了STL中的map。

class Solution {
public:
    vector<int> intersect(vector<int>& nums1, vector<int>& nums2) {

        map<int,int> n1;

        for(int i=0;i<nums1.size();i++)
        {
            n1[nums1[i]]++;
        }

        vector<int> results;

        for(int i=0;i<nums2.size();i++)
        {
            if(n1[nums2[i]]>0)
            {
                results.push_back(nums2[i]);
                n1[nums2[i]]--;
            }
        }
        return results;
    }
};

思路:因为要统计频率,题目要求不去重,所以需要统计元素出现频率。但又不知道集合中元素的大小,故无法用数组,所以采用map。

原文地址:https://www.cnblogs.com/IaCorse/p/10902197.html

时间: 2024-08-30 02:17:41

leetcode 249 250 set和map的简单用法的相关文章

GO的MAP字典简单用法示例

package main import "fmt" type PersonInfo struct { ID string Name string Address string } func main() { var personDB map[string]PersonInfo personDB = make(map[string]PersonInfo) personDB["12345"] = PersonInfo{"12345", "T

set和map的简单用法

1.set(集合)map(映射)都属于关联类容器 都支持查询一个元素是否存在并能够有效地获取元素. set集合的元素总是从小到大排列,set集合通过二分查找树实现.它具备以下两个特点: ①:独一无二的元素:不存在两个值相等的元素 ②:元素值就是关键字本身 2.#include<set> using namespace std; set<int>::iterator it; int a[]={1,2,3,4,5}; set<int>s2(a,a+5); for(it=s2

Core Data的简单用法

1 #import "ViewController.h" 2 3 // 第一步:引入头文件AppDelegate 4 #import "AppDelegate.h" 5 #import "Person.h" 6 #import "Car.h" 7 8 @interface ViewController () 9 10 // 第二步:声明属性[管理对象上下文](SQLite中是声明一个存储路径的属性) 11 @property

jquery.cycle.js简单用法实例

样式: a{text-decoration: none;} *{margin:0; padding:0;} /*容器设置*/ .player { width:216px; height:248px; background:url(http://i2.itc.cn/20120117/2cc0_da8f6c82_c8da_693d_7714_9533a013006a_3.jpg) no-repeat; background-color:#ede1d1; position:relative; padd

python lambda表达式简单用法【转】

python lambda表达式简单用法 1.lambda是什么? 看个例子: g = lambda x:x+1 看一下执行的结果: g(1) >>>2 g(2) >>>3 当然,你也可以这样使用: lambda x:x+1(1) >>>2 可以这样认为,lambda作为一个表达式,定义了一个匿名函数,上例的代码x为入口参数,x+1为函数体,用函数来表示为: 1 def g(x):2 return x+1 非常容易理解,在这里lambda简化了函数定义

iOS block-base 动画简单用法+关键帧动画设置线性变化速度的问题

本文转载至 http://www.tuicool.com/articles/aANBF3m 时间 2014-12-07 20:13:37  segmentfault-博客原文  http://segmentfault.com/blog/alan/1190000002411296 iOS的各种动画相漂亮,相信这是吸引很多人买iPhone的原因之一.不仅如此,这还是吸引我做iOS开发的一大原因,因为在iOS上给界面实现一些像样的动画实在是太轻松了! 这里就介绍一下iOS的block-based an

Android WIFI 简单用法

随着Wifi的普及,在开发App的时候对wifi的考虑越来越多了.例如程序的升级在wifi下可以省很多流量,在通信软件中的视频通话.可以实现高画质的传输等等,Android提供了WifiManager类来帮助开发者们管理Wifi.下面就简单来说一下WifiManager的简单用法把. 权限: 为了使用WfiManager 我们需要在Androidmanifest.xml 加入权限: //本例中使用了前两个.具体请按照需要添加权限. <uses-permission android:name=&quo

Android中资源文件中的字符串数组string-array简单用法

在Android中,用string-array是一种简单的提取XML资源文件数据的方法. 例子如下: 把相应的数据放到values文件夹的strings.xml文件里,或是其他自定义的xml中都可以,以下操作方法相同. <?xml version="1.0" encoding="utf-8"?> <resources> <string-array name="sports"> <item>足球<

expect简单用法

1 #!/usr/expect/bin/expect -f 2 3 4 set loginuser [lrange $argv 0 0] 5 set loginpass [lrange $argv 1 1] 6 set ipaddr [lrange $argv 2 2] 7 set port [lrange $argv 3 3] 8 set timeout [lrange $argv 4 4] 9 set from [lrange $argv 5 5] 10 set to [lrange $ar