10.3 c++ STL 初步
#include<Windows.h>
#include<iostream>
#include<algorithm> // sort swap min max lower_bound upper_bound reverse
#include<string>
#include<vector>
#include<queue> //队列 先进先出
#include<stack> // stack是先进后出
#include<set>
#include<map>
其实 这一堆头文件,可以用一个万能头文件代替#include<bits/stdc++.h>
#include<bits/stdc++.h>
using namespace std;
vector<int>v;
int main(){
for(int i=1;i<=10;i++)
v.push_back(i); //在vector类中作用为在vector尾部加入一个数据。
for(auto x : v) //auto 输出v中有定义的
{
cout<<x<<endl;
}
#include<bits/stdc++.h>
using namespace std;
vector<int>v;
vector<int>::iterator iter;
int main(){
for(int i=10;i>=1;i--)
v.push_back(i);
sort(v.begin(),v.end()); //排序,默认从小到大 //注意区间 v.begin(),v.end(),左闭右开
for(auto x : v)
cout<<x<<" ";
}
#include<bits/stdc++.h>
using namespace std;
vector<int>v;
vector<int>::iterator iter;
int main(){
int a=10,b=20;
cout<<a<<" "<<b<<endl;
swap(a,b); //交换
cout<<a<<" "<<b<<endl;
}
#include<bits/stdc++.h>
using namespace std;
vector<int>v;
vector<int>::iterator iter;
int main(){
int a=10,b=20;
cout<<a<<" "<<b<<endl;
a^=b;b^=a;a^=b; //请记住 这是一个骚操作!! 交换a和b 两次 a^=b不一样
cout<<a<<" "<<b<<endl;
}
using namespace std;
vector<int>v;
vector<int>::iterator iter;
int main(){
int a[11];
for(int i=1;i<=10;i++)
v.push_back(i);
int pos=lower_bound(v.begin(),v.end(),8)-v.begin(); //注意区间 v.begin(),v.end(),左闭右开
cout<<pos<<endl; // -v.begin()为什么不能去掉 :格式
}
// lower_bound()返回一个 iterator
//它指向在[first,last)标记的有序序列中可以插入value,
//而不会破坏容器顺序的第一个位置,
//而这个位置标记了一个第一个不小于value 的值。
using namespace std;
int main(){
string s; //直接定义string 比数组啥的好用
cin>>s;
cout<<s<<endl;
}
using namespace std;
int main(){
string s;
cin>>s;
reverse(s.begin(), s.end()); //反转顺序
cout<<s<<endl;
return 0;
}
using namespace std;
int main(){
string s="123456";
cout<<s<<endl;
return 0;
}
using namespace std;
int main(){
string s="123456";
cout<<s[1]<<endl; //输出2
return 0;
}
using namespace std;
int main(){
string s="123456",s2="qwe";
cout<<s+s2<<endl; //可以直接相加
return 0;
}
using namespace std;
int main(){
string s="123456",s2="qwe",s3=s+s2; //没有减号
cout<<s3<<endl;
return 0;
}
using namespace std;
int a[100000];
int main(){
for(int i=1;i<=10;i++)
{
int x;cin>>x;
if(a[x]==1) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
a[x]=1; //如果此时输入的数字,没有出现过,那么输出no 并把这个数字标记为1,下次输入的时候,会输出yes
}
using namespace std;
set<int>s; // For里 1e7 就会超过1s 就会炸掉 10 的7次方
int main(){
for(int i=1;i<=10;i++)
{
int x;cin>>x;
if(!s.count(x)) cout<<"NO"<<endl;
else cout<<"YES"<<endl;
s.insert(x);
}
在queup prior 优先队列 输入的自动排序 从小到大
multiset<int >s 也是set 的一种形式,可以重复,从小到大自动排序
using namespace std;
priority_queue<int>a; //队列 先进先出
int main(){
int b;
for(int i=0;i<10;i++){
cin>>b;
a.push(b);
}
for(int i=0;i<10;i++){
cout<<a.top()<<" ";
a.pop();
} //取得队首元素操作top(); 那 是最小的队首还是对大的:?
}
// 输出 121 100 88 77 66 52 44 4 3 1
/*empty() 如果队列为空,则返回真
pop() 删除对顶元素,删除第一个元素
push() 加入一个元素
size() 返回优先队列中拥有的元素个数
top() 返回优先队列对顶元素,返回优先队列中有最高优先级的元素 */
10.3 c++ STL 初步的更多相关文章
- Go语言之Windows 10开发工具LiteIDE初步使用
Intel Core i5-8250U,Windows 10家庭中文版,go version go1.11 windows/amd64,LiteIDE X34.1 在RUNOOB.COM的Go语言教程 ...
- 2020.2.27——STL初步
注:本文主要针对STL中的常用的操作进行总结 目录: 1.swap 2.sort 3.reverse 4.min,max(比较简单,暂且略过) 5._gcd 6.lower_bound &&a ...
- (STL初步)不定长数组:vector
STL是指C++的标准模板库.(存储着一些常用的算法和容器) vector是一个不定长数组.它把一些常用的操作”封装“在vector类型内部. 例如,a是一个vector.1对元素的操作有,可以用a. ...
- 【STL初步】不定长数组:vector + 集合:set + 映射:map
一.vector 为了节省空间,有时我们会使用动态数组vector. 定义动态数组 vector<类型名>变量名 vector<int>que //定义que为一个int类型的 ...
- AcWing STL初步学习
vector, 变长数组,倍增的思想 size() 返回元素个数 empty() 返回是否为空 clear() 清空 front()/back() push_back()/pop_back() beg ...
- STL初步学习(queue,deque)
4.queue queue就是队列,平时用得非常多.栈的操作是只能是先进先出,与栈不同,是先进后出,与之后的deque也有区别.个人感觉手写队列有点麻烦,有什么head和tail什么的,所以说 STL ...
- STL初步学习(vector)
前文 初三下学期进入新的学习,对于前两年的学习内容因为各种原因 上课打游戏,睡觉,看视频 已经遗忘,忘记如何使用,算是重新学习一次信息学,希望能尽快将以前的内容弥补上来,争取能在CSP-2020取得一 ...
- STL初步学习(set)
2.set set可以看作一个集合,可以实现自动排序(升序)和去重 在许多题目中,都可以使用这个模板库,减少很多操作,例如P1923 第k小数,当然,这道题有很多奇奇怪怪的做法,分值都不同,之后会讲解 ...
- STL初步学习(map)
3.map map作为一个映射,有两个参数,第一个参数作为关键值,第二个参数为对应的值,关键值是唯一的 在平时使用的数组中,也有点类似于映射的方法,例如a[10]=1,但其实我们的关键值和对应的值只能 ...
随机推荐
- Leetcode:110. 平衡二叉树
Leetcode:110. 平衡二叉树 Leetcode:110. 平衡二叉树 点链接就能看到原题啦~ 关于AVL的判断函数写法,请跳转:平衡二叉树的判断 废话不说直接上代码吧~主要的解析的都在上面的 ...
- js—数字那些事儿
进制之间互相转化 a=133 十进制转成其他进制 a.toString(num) a.toString(2); //转化成二进制,返回"10000101" a.toString(8 ...
- css3新增边框、阴影、边框、背景、文本、字体
css3和css有什么区别?简单来讲css3是css(层叠样式表)技术的升级版本,css3新特征有很多,例如圆角效果.图形化边界.块阴影与文字阴影.使用RGBA实现透明效果.渐变效果.使用@Font- ...
- Gartner评估:众包将掀起IT服务市场的革命
国际IT顾问与咨询公司Gartner发布评估报告,称众包是中国的一种新兴业务模式,将掀起IT服务市场的革命.然而,只有很少的的服务提供商会构建众包平台来尝试使用该业务模式.IT服务提供商的业务部门负责 ...
- 两分支部署Hexo
最近把原本部署在GitHub上的hexo同时部署到码云上,速度快到飞起. 可做对比,我的GitHub Pages像乌龟一样慢吞吞,我的Gitee Pages像兔子一样敏捷. 使用hexo,如果换了电脑 ...
- 吴裕雄--天生自然HADOOP操作实验学习笔记:使用hive操作hbase
实验目的 熟悉hive和hbase的操作 熟悉hadoop.hbase.hive.zookeeper的关系 熟练大数据环境的搭建 学会分析日志排除问题 实验原理 1.hive整合hbase原理 前面大 ...
- Java 日期格式化,Java 日期工具类,Java Date工具类
================================ ©Copyright 蕃薯耀 2020-01-19 https://www.cnblogs.com/fanshuyao/ import ...
- C++->10.3.5.从键盘上输入职工的编号,从职工信息文件中查找该职工资料,查找成功时显示职工姓名、电话号码,邮政编码和地址。
p=getchar(); } printf("\n"); rewind(in); //文件流指针移到文件开始位置 p=fgetc(in); while(!feof ...
- 双向链表的简单Java实现-sunziren
写在前面,csdn的那篇同名博客就是我写的,我把它现在在这边重新发布,因为我实在不想用csdn了,那边的广告太多了,还有就是那个恶心人的“阅读更多”按钮,惹不起我躲得起. 在上次分享完单向链表的简单编 ...
- simmon effect(psychology experiment) : this time, we add file_function who can creat a file in the window which contains our result
#the real experiment for simon effect #load the library which is our need import pygame import sys i ...