programming review (c++): (1)vector, linked list, stack, queue, map, string, bit manipulation
编程题常用知识点的review。
most important: 想好(1)详尽步骤(2)边界特例,再开始写代码。
I.vector
#include <iostream>
//0.头文件。 特性: 连续存储,动态双倍分配增长
#include <vector>
#include <algorithm> //relevant
using namespace std; bool comp(int a,int b){
return a>b;
} int main(){ //1.创建与初始化
vector<int> v1(,);
vector<int> v2(v1); //也可拷贝初始化 vector<int> v2=v1;
vector<vector<int>> ivec(,v1); //二维vector //2.返回数量与判断空
if(v1.empty())
cout<<"it's empty";
auto n=v1.size(); //3.修改元素与遍历元素
for(int i=;i<n;i++)
v1[i]=; vector<int>::iterator it; //迭代器
for(it=v1.begin();it!=v1.end();it++)
*it=; //4.插入与删除元素
v1.push_back();
v1.pop_back(); v1.insert(v1.begin()+, ); //把9插入到第3个元素后面
v1.erase(v1.begin()+); //把第3个元素后面的那个元素删掉 //5.相关函数 reverse sort
reverse(v1.begin(),v1.end());
sort(v1.begin(),v1.end(),comp); //等价于 sort(v1.rbegin(),v1.rend()); }
II.linked list
#include <iostream>
#include <vector>
//0.struct struct ListNode {
int val;
ListNode *next;
ListNode(int x) : val(x), next(NULL) {} //定义了节点的初始化方法
}; using namespace std; int main(){ vector<int> ivec{,,,,,};
//1.创建与初始化
ListNode *head=new ListNode(); //申请一个新节点,注意 head= new ListNode(0)与 head= ListNode(0)的区别
ListNode *p=head,*q;
for(auto i:ivec){ //此乃尾插法,还有头插法,根据情况选择合适的,注意现在有头节点
q=new ListNode(i);
p->next=q;
p=q;
} //2.遍历元素、插入删除元素
p=head;
while(p->next!=NULL){
if(p->next->val==){
q=new ListNode();
q->next=p->next->next;
p->next=q;
}
} /* 3.经典操作: (1) 原地reverse——头插法和尾插法的运用;
(2) 判断cycle——快慢指针;
(3) 找中间节点、找间隔节点——快慢指针;
}
*/ }
III.stack && queue
#include <iostream>
#include <vector> //0.头文件 经常以vector模拟
#include <stack>
#include <queue> using namespace std; int main(){ //1.stack 创建与初始化,基本操作 push pop top empty size
stack<int> myStack;
myStack.push();
myStack.push();
cout<<myStack.top()<<endl;
myStack.pop();
cout<<myStack.size()<<myStack.empty()<<endl; //2.queue 创建与初始化,基本操作 push pop front back empty size
queue<int> myQueue;
myQueue.push();
myQueue.push();
cout<<myQueue.front()<<endl;
cout<<myQueue.back()<<endl;
myQueue.pop();
cout<<myQueue.size()<<myQueue.empty()<<endl; }
IV.map
#include <iostream>
//0.头文件 优点:快速访问/空间换时间/桶的思想,key用来去重,value用来存辅助信息。注意,有时直接用数组进行hash,而不需要借助<map>
#include <map>
using namespace std; int main(){ //1.创建
map<string,int> myMap; //2.访问、修改、增加元素
myMap["Tom"]=; myMap["Lucy"]=; myMap["Jack"]=; //3.删除元素
myMap.erase("Tom"); //也可使用 myMap.erase(myMap.find("hi")); //4.通过key查找元素
if (myMap.find("Tom")==myMap.end())
cout<<myMap.count("Tom")<<endl; //5.遍历,map内部以key的升序排列
for(auto it=myMap.begin();it!=myMap.end();it++){
cout<<it->first<<endl;
cout<<it->second<<endl;
} }
V.string
#include <iostream>
#include <vector>
//0.头文件
#include <string>
#include<sstream> //辅助 using namespace std; int main(){ //1.创建,初始化
string x="hello world",y="ld s";
getline(cin,y); //获得一行,也可再加个终止符参数 //2.常用函数与vector相同 empty, size, push_back, 下标访问 //3.+ - < > =运算符的重载 //4.关于字符变量函数 isalnum,isalpha,isdigit tolower,toupper //5.获得子串
string sub=x.substr(,); // 第1个位置开始,长度为3的子串 //6.交换两个字符串
y.swap(x); //7.查找字串
auto t=y.find(x,);
if(t!=string::npos)
cout<<t; //8.split功能
istringstream strcin(x);
string s;
vector<string> res;
while(strcin >> s)
res.push_back(s); }
VI.bit manipulation
- 与 a&b 1010&1100=1000
- 或 a|b 1010|1100=1110
- 异或 a^b 1010^1100=1001
- 按位取反 ~a ~1010=0101
- 左移 a<<1 1010<<1=10100
- 带符号右移 a>>1 -1010>>1=-101
- 无符号右移 a>>>1
programming review (c++): (1)vector, linked list, stack, queue, map, string, bit manipulation的更多相关文章
- STL中stack/queue/map以及Boost unordered_map 的使用方法
一.stackstack 模板类的定义在<stack>头文件中.stack 模板类需要两个模板参数,一个是元素类型,一个容器类型,但只有元素类型是必要的,在不指定容器类型时,默认的容器类型 ...
- java三篇博客转载 详解-vector,stack,queue,deque
博客一:转载自http://shmilyaw-hotmail-com.iteye.com/blog/1825171 java stack的详细实现分析 简介 我们最常用的数据结构之一大概就是stack ...
- STL容器用法速查表:list,vector,stack,queue,deque,priority_queue,set,map
list vector deque stack queue priority_queue set [unordered_set] map [unordered_map] multimap [uno ...
- STL容器适配器 stack, queue
stack是一种后进先出(last in first out)的数据结构.它只有一个出口,如图所示.stack允许新增元素,删除元素,取得最顶端元素.但除了最顶端外,没有其他任何地方可以存储stack ...
- Stack&&Queue
特殊的容器:容器适配器 stack queue priority_queue:vector+堆算法---->优先级队列 stack: 1.栈的概念:特殊的线性结构,只允许 ...
- 数据结构设计 Stack Queue
之前在简书上初步总结过几个有关栈和队列的数据结构设计的题目.http://www.jianshu.com/p/d43f93661631 1.线性数据结构 Array Stack Queue Hash ...
- POJ 3096 Surprising Strings(STL map string set vector)
题目:http://poj.org/problem?id=3096 题意:给定一个字符串S,从中找出所有有两个字符组成的子串,每当组成子串的字符之间隔着n字符时,如果没有相同的子串出现,则输出 &qu ...
- PAT 1039 Course List for Student (25分) 使用map<string, vector<int>>
题目 Zhejiang University has 40000 students and provides 2500 courses. Now given the student name list ...
- js in depth: event loop & micro-task, macro-task & stack, queue, heap & thread, process
js in depth: event loop & micro-task, macro-task & stack, queue, heap & thread, process ...
随机推荐
- linux 实现共享内存同步
本文主要对实现共享内存同步的四种方法进行了介绍. 共享内存是一种最为高效的进程间通信方式,进程可以直接读写内存,而不需要任何数据的拷贝.它是IPC对象的一种. 为了在多个进程间交换信息,内核专门留出了 ...
- paramiko模块及ssh远程登陆
ssh实现远程登陆一般有两种方式,一种就是用户密码登陆,另一种是密钥登陆(当然默认是要服务端打开ssh服务). 我这里使用这两种方法操作一下远程登陆,测试客户端是本机的root与jeff用户,远程连接 ...
- python 生成式和生成器
#!/usr/bin/env python # -*- coding:utf-8 -*- # @Time : 2017/10/17 21:46 # @Author : lijunjiang # @Fi ...
- 【转载】SQL Server XML Path
FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作.那么以一个实例为主 ...
- GROOVY入门
refer to 精通Groovy(IBM)https://www.ibm.com/developerworks/cn/education/java/j-groovy/j-groovy.html re ...
- python调用phantomjs组件(windows和linux)
phantomjs在windows和linux系统,可以通selenium的webdriver直接调用,所以只要将phantomjs程序加载到python程序目录下. 示例代码如下所示: #建立Pha ...
- Xamarin XAML语言教程将XAML设计的UI显示到界面
Xamarin XAML语言教程将XAML设计的UI显示到界面 如果通过XAML将UI设计好以后,就可以将XAML中的内容显示给用户了,也就是显示到界面上.由于创建XAML文件方式的不同,所以将XAM ...
- Linux学习之十六-Linux用户管理
Linux用户管理 Linux系统跟Windows系统一样,可以创建不同的用户,不同的用户组.在不同用户下使用系统具有相应的权限 创建一个普通用户时,会修改几个文件,拷贝一些初始文件到用户家目录中 修 ...
- 转: 为什么做java的web开发我们会使用struts2,springMVC和spring这样的框架?
from: https://github.com/RubyLouvre/agate/issues/8 今年我一直在思考web开发里的前后端分离的问题,到了现在也颇有点心得了,随着这个问题的深入,再加以 ...
- 查看Linux上MySQL版本信息
如果MySQL是用rpm或者yum安装的,可用 #rpm -qa|grep mysql查看. 如: [root@asd76 ~]# rpm -qa|grep mysqlmysql-5.1.73-3.e ...