HDU 2006 求奇数的乘积(水题)
972
2022-08-23
STL中的pair方法详解
template
参数:T1是第一个值的数据类型,T2是第二个值的数据类型。
功能:pair将一对值组合成一个值,这一对值可以具有不同的数据类型(T1和T2),两个值可以分别用pair的两个公有函数first和second访问。
具体用法:
1.定义(构造):
pair
2.访问两个元素(通过first和second):
pair
输出结果:1 2.5
3.赋值operator = :
(1)利用make_pair:
pair
(2)变量间赋值:
pair
pair的类型: pair 是 一种模版类型。每个pair 可以存储两个值。这两种值无限制。也可以将自己写的struct的对象放进去。。
pair
都可以。。。 应用:如果一个函数有两个返回值 的话,如果是相同类型,就可以用数组返回,如果是不同类型,就可以自己写个struct ,但为了方便就可以使用 c++ 自带的pair ,返回一个pair,其中带有两个值。除了返回值的应用,在一个对象有多个属性的时候 ,一般自己写一个struct ,如果就是两个属性的话,就可以用pair 进行操作。。。 应用pair 可以省的自己写一个struct 。。。如果有三个属性的话,其实也是可以用的pair 的 ,极端的写法
pair <int ,pair
写法极端。(后边的两个 > > 要有空格,否则就会是 >> 位移运算符) make_pair:
pair
有这两种写法来生成一个pair。
如何取得pair的值呢。。 每个pair 都有两个属性值 first 和second
cout< typedef pair make_pair方法小结: std::pair主要的作用是将两个数据组合成一个数据,两个数据可以是同一类型或者不同类型。例如std::pair template pair make_pair(T1 a, T2 b) { return pair(a, b); } 一般make_pair都使用在需要pair做参数的位置,可以直接调用make_pair生成pair对象。 另一个使用的方面就是pair可以接受隐式的类型转换,这样可以获得更高的灵活度。但是这样会出现如下问题:例如有如下两个定义: std::pair 其中第一个的second变量是float类型,而make_pair函数会将second变量都转换成double类型。这个问题在编程是需要引起注意。下面是一段pair与make_pair的例子程序: #include 其运行结果如下: 1The price of tomatoes is $3.252The price of lightbulbs is $0.993The price of shoes is $20 pair vs make_pairmake_pair constructs a pair object.template pair make_pair(T1 x, T2 y) { return pair(x, y); } eg: std::pair("sn001", 12.5); std::make_pair("sn001", 12.5); 两者效果一样。 倘若:std::pair("sn002", 12.6); // 12.6's datatype is float std::make_pair("sn002",12.6); // 12.6's datatype is double 使用: std::pair m_pairA; m_pairA = std::make_pair("sn001", 12.5); std::cout< 小结: make_pair创建的是一个pair对象。使用都很方便,针对成对出现的数据,如书的ISBN对应一个书名。 pair是单个数据对的操作,pair是一struct类型,有两个成员变量,通过first,second来访问,用的是“.”访问。 map是一个关联容器,里面存放的是键值对,容器中每一元素都是pair类型,通过map的insert()方法来插入元素(pair类型)。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~