C++ push_back()和back() 、pop()、push()、emplace() 和 emplace_back()

1 push_back()和back()

c.push_back(X) 将元素X加入到c容器的最后一位。
c.back() 返回c容器的最后一个元素的值,并不是该元素的地址。

2 push_back()和pop_back( )

push_back() 在Vector最后添加一个元素(参数为要插入的值);
删除Vector容器中的最后一个元素;

3 push()和pop()

进栈 push()
入栈:在栈顶(数组的尾部)添加指定的元素,并返回新数组的长度。

出栈 pop()
出栈:删除栈顶(数组的尾部)的一个元素,并且返回它的值。

其他
shift():删除数组头部的第一个元素,并返回删除的元素。
unshift():在数组头部的第一个元素前添加一个元素,并返回新数组的长度。

4 emplace() 和 emplace_back()

emplace、emplace_back、emplace_front,分别对应insert、push_back、push_front;

(push_back()和emplace_back())详解

  • 12
    点赞
  • 69
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
引用中给出了使用push_back()函数在字符串后附加字符的方法。该函数的时间复杂度为O(1),即常数时间。在这个例子中,字符串s的长度是固定的,因此push_back()函数的效率是非常高的。 然而,对于动态变长的字符串,如使用vector容器的情况,push_back()函数的效率会有所下降。因为在向末尾添加元素时,可能需要重新分配内存空间,并将原有的元素复制到新的内存空间中。这个操作的时间复杂度是O(n),其中n是当前元素个数。 因此,在使用push_back()函数时,需要根据具体情况来判断其效率。如果字符串的长度是固定的,或者不需要频繁添加元素,那么push_back()函数的效率是很高的。但如果字符串的长度不确定,而且需要频繁添加元素,那么可能需要考虑使用其他的数据结构或者优化算法来提高效率。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [std::string操作--push_backpop_back、append](https://blog.csdn.net/qq_44778120/article/details/123420498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [c++ emplace_backpush_back](https://download.csdn.net/download/weixin_38698403/14042601)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

R-G-B

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值