---恢复内容开始---

C++ STL 与ACM竞赛相关的应用

1、vector

vector是动态数组,可以理解为是能够根据需要随时申请内存的动态数组。

常用操作如下:

  • 容量

    • vec.size()    向量大小
    • vec.empty()  向量判空 (如果为空==true、不为空==false)
  • 修改
    • vec.push_back()   向向量末尾添加一个元素
    • vec.pop_back()   删除向量末尾元素
    • vec.insert()     向向量中任意位置插入元素
    • vec.erase()    删除任意位置元素
    • vec.swap(,)    交换任意两个位置的向量
    • vec.clear()    清空向量元素
  • 迭代器
    • vec.begin()    开始指针
    • vec.end()    末尾指针
  • 元素访问
    • vec[1],vec[2]   下标直接访问
    • vec.front()    访问第一个元素
    • vec.back()    访问最后一个元素

示例:

#include <bits/stdc++.h>
using namespace std; vector<int>v;///声明部分
int main()
{
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();///插入元素
if(!v.empty())///判断是否为空
{
v.pop_back();///3 出
v.pop_back();///1 出
v.pop_back();///2 出
}
///迭代器的用法
vector <int> :: iterator it;
for(it=v.begin();it != v.end(); it++)///遍历元素
{
cout<<*it<<endl;
}
v.insert(it,,);///vector 后面会输出 4个0
///插入的位置取决于指针的位置
for(it=v.begin();it != v.end(); it++)///遍历元素
{
cout<<*it<<endl;
}
}

2、set和multiset

set顾名思义就是集合,里面没有重复的元素;但multiset可以有重复的元素,并且能够自动的从小到大排序

常用操作如下:

  • 大小、判空

    • s.size()  返回元素个数
    • s.empty()  判断是否为空
  • 增加、删除函数
    • s.insert()  向集合内插入元素
    • s.erase()  删除集合内有确定值的元素
  • 迭代器
    • iterator insert(iterator it,x):在迭代器it处插入元素x
    • iterator erase(iterator it):删除迭代器指针it处元素
    • iterator erase(iterator first,iterator last):删除[first, last)之间元素
    • iterator begin():返回首元素的迭代器指针
    • iterator end():返回尾元素的迭代器指针   
    • reverse_iterator rbegin():返回尾元素的逆向迭代器指针 (即最后一个)  
    • reverse_iterator rend():返回首元素前一个位置的迭代器指针

示例

为了更好的展示STL中的这个功能,我打算在这里放一道题

UVa 11136  

题目大意:超市抽奖,找到每天消费最多的和消费最少的,拿出来给他们奖励,奖励就是消费之差。

下面是代码

#include <bits/stdc++.h>
using namespace std;
int main()
{
long long maxx,minn,sum; ///根据题目要求要用long long
int k,p,q;
multiset<int >s;
int n;
while(scanf("%d",&n) && n)
{
sum=;
s.clear();///在一次开始之前需要清空multiset
cin>>k;
while(k--)
{
cin>>p;
for(int i=;i<p;i++)
{
cin>>q;
s.insert(q);///multiset的插入操作
}
///multiset 自动排序
minn=*(s.begin()); ///找到最小的(可以重复)
maxx=*(s.rbegin()); ///反序查找第一个,也就是最后一个
///s.end() 表示的是最后一个的下一个 sum+= maxx-minn; s.erase(s.find(maxx)); ///s.erase() 括号里面若是值,会把所有相同重复的都删掉
s.erase(s.find(minn)); ///s.find () 若有,只返回一个值
}
cout<<sum<<endl;
}
}

---恢复内容开始---

C++ STL 与ACM竞赛相关的应用

1、vector

vector是动态数组,可以理解为是能够根据需要随时申请内存的动态数组。

常用操作如下:

  • 容量

    • vec.size()    向量大小
    • vec.empty()  向量判空 (如果为空==true、不为空==false)
  • 修改
    • vec.push_back()   向向量末尾添加一个元素
    • vec.pop_back()   删除向量末尾元素
    • vec.insert()     向向量中任意位置插入元素
    • vec.erase()    删除任意位置元素
    • vec.swap(,)    交换任意两个位置的向量
    • vec.clear()    清空向量元素
  • 迭代器
    • vec.begin()    开始指针
    • vec.end()    末尾指针
  • 元素访问
    • vec[1],vec[2]   下标直接访问
    • vec.front()    访问第一个元素
    • vec.back()    访问最后一个元素

示例:

#include <bits/stdc++.h>
using namespace std; vector<int>v;///声明部分
int main()
{
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();
v.push_back();///插入元素
if(!v.empty())///判断是否为空
{
v.pop_back();///3 出
v.pop_back();///1 出
v.pop_back();///2 出
}
///迭代器的用法
vector <int> :: iterator it;
for(it=v.begin();it != v.end(); it++)///遍历元素
{
cout<<*it<<endl;
}
v.insert(it,,);///vector 后面会输出 4个0
///插入的位置取决于指针的位置
for(it=v.begin();it != v.end(); it++)///遍历元素
{
cout<<*it<<endl;
}
}

2、set和multiset

set顾名思义就是集合,里面没有重复的元素;但multiset可以有重复的元素,并且能够自动的从小到大排序

常用操作如下:

  • 大小、判空

    • s.size()  返回元素个数
    • s.empty()  判断是否为空
  • 增加、删除函数
    • s.insert()  向集合内插入元素
    • s.erase()  删除集合内有确定值的元素
  • 迭代器
    • iterator insert(iterator it,x):在迭代器it处插入元素x
    • iterator erase(iterator it):删除迭代器指针it处元素
    • iterator erase(iterator first,iterator last):删除[first, last)之间元素
    • iterator begin():返回首元素的迭代器指针
    • iterator end():返回尾元素的迭代器指针   
    • reverse_iterator rbegin():返回尾元素的逆向迭代器指针 (即最后一个)  
    • reverse_iterator rend():返回首元素前一个位置的迭代器指针

示例

为了更好的展示STL中的这个功能,我打算在这里放一道题

UVa 11136  

题目大意:超市抽奖,找到每天消费最多的和消费最少的,拿出来给他们奖励,奖励就是消费之差。

下面是代码

#include <bits/stdc++.h>
using namespace std;
int main()
{
long long maxx,minn,sum; ///根据题目要求要用long long
int k,p,q;
multiset<int >s;
int n;
while(scanf("%d",&n) && n)
{
sum=;
s.clear();///在一次开始之前需要清空multiset
cin>>k;
while(k--)
{
cin>>p;
for(int i=;i<p;i++)
{
cin>>q;
s.insert(q);///multiset的插入操作
}
///multiset 自动排序
minn=*(s.begin()); ///找到最小的(可以重复)
maxx=*(s.rbegin()); ///反序查找第一个,也就是最后一个
///s.end() 表示的是最后一个的下一个 sum+= maxx-minn; s.erase(s.find(maxx)); ///s.erase() 括号里面若是值,会把所有相同重复的都删掉
s.erase(s.find(minn)); ///s.find () 若有,只返回一个值
}
cout<<sum<<endl;
}
}

知识点总结——STL相关(持续补充)的更多相关文章

  1. 利用redis实现分布式锁知识点总结及相关改进

    利用redis实现分布式锁知识点总结及相关改进 先上原文,本文只为总结及对相关内容的质疑并提出若干意见,原文内容更详细https://www.cnblogs.com/linjiqin/p/800383 ...

  2. [20190329]探究sql语句相关mutexes补充2.txt

    [20190329]探究sql语句相关mutexes补充2.txt --//昨天测试sql语句相关mutexes,看看如果出现多个子光标的情况. 1.环境:SCOTT@book> @ ver1P ...

  3. 侯捷STL学习(12)--STL相关内容hash+tuple

    layout: post title: 侯捷STL学习(12) date: 2017-08-01 tag: 侯捷STL --- 第四讲 STL相关的内容 Hash Function 将hash函数封装 ...

  4. phpstorm 工具使用技巧(持续补充中。。。)

    phpstorm 工具使用技巧(持续补充中...) 一.phpstorm大小写切换 1.选择要转换的目标字符串: //普通商家,普通折扣默认值'COMMON_DISCOUNT'=>10.00, ...

  5. CSS琐碎知识点(持续补充)

    一.字体单位,pt?px?em?rem? pt:磅,一种固定长度的绝对的度量单位,是能够使用测量设备测得的长度,印刷业上经常使用,一般用于页面打印排版. px:屏幕设备上能显示出的最小的一个物理点,这 ...

  6. HTML琐碎知识点(持续补充)

    一.table标签 <table> <thead> <tr> <th>111</th> </tr> </thead> ...

  7. 【转】APP被苹果App Store拒绝的N个原因(持续补充)

    作为iOS开发者,估计有很多都遇到过APP提交到App Store被拒,然后这些被拒的原因多种多样,今天dApps收集了常见的被拒的原因,以便更多开发者了解. 1.程序有重大bug,程序不能启动,或者 ...

  8. 【转】C++ STL 相关的问题集合

    3.C++ STL中vector的相关问题:    (1).调用push_back时,其内部的内存分配是如何进行的?    (2).调用clear时,内部是如何具体实现的?若想将其内存释放,该如何操作 ...

  9. 前端知识点一HTML相关知识点

    1.浏览器页面有哪三层构成,分别是什么,作用是什么? 构成:结构层.表示层.行为层 分别是:HTML.CSS.JavaScript 作用:HTML实现页面结构,CSS完成页面的表现与风格,JavaSc ...

随机推荐

  1. [转载]前端 阿里p6面试题集锦含答案

    1.说一下你了解CSS盒模型. 盒模型分为:IE的怪异盒模型和标注浏览器的盒模型,然后可以通过box-sizing属性控制两种盒模型的变换. 2.说一下box-sizing的应用场景. 这个也不难,简 ...

  2. 百川sdk----自己的WebViewClient不被执行【废弃,新版本百川已修复此问题】

    我在百川sdk的旺旺群中,追问这个问题N多次,一直没有人答复,哎,凡事都要靠自己..... 1.先查看下百川sdk中,是怎么处理咱们传递过去的 WebViewClient public class l ...

  3. Spring MVC 上下文(ApplicationContext)初始化入口

    Spring 常用上下文容器有哪些 ApplicationContext ClassPathXmlApplicationContext ApplicationContext context = new ...

  4. 《Java编程思想》读书笔记-赋值操作符

    在最底层,Java中的数据是通过使用操作符来操作的.接下来我们逐一认识一些操作符. 怎么运用操作符 操作符接受一个或多个参数,并生成一个新值. 基本操作符 赋值操作符 符号:= 作用:取右边的值,把它 ...

  5. Visual C++ 6.0中if的简单用法

    # include<stdio.h> int main (void) { > ) printf("AAAA"); printf("BBBB") ...

  6. Python学习之路并发编程--信号量、事件、队列及生产消费模型

    1. 信号量 对于多进程来说,多个进程同时修改数据,就可能出现安全隐患,所以引入了锁,这一机制,但锁只能有一把来控制一个的开关,当你需要几把锁的时候,就可能用到信号量的概念.他是用了锁的原理,内置了一 ...

  7. JAVA日常之三

    一.Main方法的args参数 args[] 是程序运行前可传入的参数,比如 java HelloWorld a,那么在HelloWorld的main方法里面 args就是{"a" ...

  8. apply,call以及bind的区别

    每个函数都包含两个非继承而来的方法:apply()和 call(). 这两个方法的用途都是在特定的作用域中调用函数,实际上等于设置函数体内 this 对象的值. 一.apply() apply()方法 ...

  9. npm 遇到的坑

    在脚手架方式搭建react项目时,输入命令:npm install -g create-react-app,出现错误: UNABLE_TO_VERIFY_LEAF_SIGNATUREUNABLE_TO ...

  10. day11.2lambda函数表达式 及其返回值注意事项

    lambda表达式 用于表示简单的函数 func1=lambda 参数:一句话函数体(默认返回函数体内执行的内容) 1.1结构 func=lambda a1,a2 : a1+100 val=func( ...