刷算法题常用C++知识

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_29978597/article/details/85536707

刷算法题常用C++知识

写在前面

本文适合具备c语言基础,想快速上手c++刷题的人,如有不足之处,欢迎各位评论。

1.输入(cin)

char a,b; cin>>a>>b; cout<<a<<b<<endl;//给a,b赋值,输出a,b的值,换行
注意:

cin读入数据的效率略低于scanf。
cin读取数据,以空格、tab或换行作为分隔符。
例如(输入):m n
a与b的值就分别是m和n,m与n之间的空格被直接忽略了。
如果使用

scanf("%c%c",&a,&b);

a与b的值就分别是m和空格,中间的空格被成功读取。

scanf("%c %c",&a,&b);

格式化输入后,a与b的值即为m和n。

总结:

在对输入效率没有过高要求且数据是以空格、tab或换行作为分隔符德情况下,可以使用cin方便操作。

2.字符串(string)

2.1 声明赋值

string s1,s2;//声明空字符串s1,s2
s1="hello";//给s1赋值
s2=s1;//把s1的值赋给s2,s2的值为"hello"

2.2 字符串连接

string s3=s1+s2;//将s1,s2连接的值赋给s3,s3的值为"hellohello"

2.3 字符串截取

两种形式,substr(pos,n)和substr(pos)。

string s4=s3.substr(0,3);//s4的值为s3下标0开始往后3个字符,即"hel"
string s5=s3.substr(4);//s4的值为s3下标4开始后面所有字符,即"ohello"

2.4 比较操作符

string重载了很多操作符,对字符串比较十分方便。
==,!=,<,>,<=,>=都可以用来做操作符两端字符串的比较,具体比较规则参照字符串的字典序大小。

2.5 获取长度

可以用s.length()或者s.size(),没有区别。

s1.length();//5
s1.size();//5

3.引用(&)

这里主要说一下引用和指针的区别。

  • 指针存储的是一块内存的地址,通过地址,可以访问这块内存;
    引用则是一个变量的别名,在创建时必须初始化。
  • 引用在初始化后不能改变,指针可以修改指向的对象
int *p=&a;//初始化指针p,指向a的地址
int &r=a;//给a取一个别名r,可以说r就是a

函数传参:以函数swap(a,b)为例。

  1. 指针写法
void swap(int *a,int *b)
{
	int tmp;
	tmp = *a;
	*a = *b;
	*b = tmp;
}
  1. 引用写法
void swap(int &a,int &b)
{
	int tmp;
	tmp = a;
	a = b;
	b = tmp;
}

4.常用STL容器

C++ STL(标准模板库)是一套功能强大的 C++ 模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量、链表、队列、栈。

4.1 vector(动态数组)

头文件#include<vector>

//声明一个int型的动态数组
vector<int> vec;

//vec的大小
vec.size();

//判断是否为空
vec.empty();

//vec的最大容量
vec.max_size();

//修改vec的大小
vec.resize();

//末尾添加元素
vec.push_back();      

//末尾删除元素
vec.pop_back();      

//下标访问
vec[0];

//迭代器遍历
vector<int>::iterator it;
for (it = vec.begin(); it != vec.end(); it++)
    cout << *it << endl;
    
//下标遍历
for (unsigned i = 0; i < vec.size(); i++) {
    cout << vec[i]<< endl;
}

4.2 set(集合)

头文件#include<set>
在set中每个元素的值都唯一,而且系统能根据元素的值自动进行排序。
比如先后向集合中插入4 3 3 2 2 1,最后集合中的结果为1 2 3 4。

//声明一个int型的集合
set<int> s;

//set的大小
s.size();

//判断是否为空
s.empty();

//set的最大容量
s.max_size();

//向集合中添加元素
insert(value);      

//在集合中删除元素
erase(value);      

//返回集合第一个元素的地址
s.begin();

//返回集合最后一个元素的地址
s.end();

//迭代器遍历
set<int>::iterator it;
for (it = s.begin(); it != s.end(); it++)
    cout << *it << endl;
    
//判断指定值是否存在于集合中
if(s.find(value) == s.end())
	cout<<value<<"不在集合中"<<endl;

4.3 map(映射)

头文件#include<map>
自动建立Key(关键字)- value(值)的对应。key 和 value可以是任意你需要的类型。

//声明一个关键字为string型,值为int型的集合
map<string,int> m;

//map的大小
m.size();

//判断是否为空
m.empty();

//向集合中添加元素
m["test"]=2;

//在集合中删除元素
m.erase("test");      

//返回集合第一个元素的地址
m.begin();

//返回集合最后一个元素的地址
m.end();

//迭代器遍历
map<string,int>::iterator it;
for (it = m.begin(); it != m.end(); it++)
    cout << it->first()<<it->second() << endl;

//判断指定关键字的数据是否存在于映射中
if(m.find(key) == m.end())
	cout<<key<<"不在映射中"<<endl;

4.4 stack(栈)

头文件#include<stack>

stack<int> s;//声明一个空栈
s.size();//栈大小
s.push();//压栈
s.top();//访问栈顶元素
s.pop();//移除栈顶元素

4.5 queue(队列)

头文件#include<queue>

queue<int> q;//声明一个空队列
q.size();//队大小
q.push();//入队
q.front();//访问队首元素
q.back();//访问队尾元素
q.pop();//移除队首元素

猜你喜欢

转载自blog.csdn.net/qq_29978597/article/details/85536707