1.stack / queue(栈,队列)
stack
构造函数 stack
入栈 v.push(i);
出栈 v.pop();
是否为空 v.empty()
queue
构造函数 queue
入队 v.push(i);
出队 v.pop();
是否为空 v.empty();
代码:
#include
#include /*引入栈容器*/
#include /*引入队列容器*/
using namespace std; /*引入标准命名空间*/
void test0()
{
/**** 创建栈容器对象 *****/
stack v;
/**** 入栈数据:1,2,3,4,5,6 ***/
for(int i = 1; i < 7;i++)
{
v.push(i);
cout << "入栈栈顶数据:" << v.top() << endl;
}
cout <<"—————————— 出栈 ——————————" << endl;
/**** 出栈数据:6,5,4,3,2,1 ***/
while(v.size() != 0)
{
cout << "出栈栈顶数据:" << v.top() << endl;
v.pop();
}
/**** 判断栈是否为空 *****/
cout << "栈是否为空:" << (v.empty() == true ? "为空" : "非空") << endl;
}
void test1()
{
/*** 1.创建队列容器对象 ***/
queue v;
/*** 2.入队数据: 1,2,3,4,5,6 ****/
for(int i = 1; i < 7;i++)
{
v.push(i);/*入队*/
cout << "入队队头元素:" << v.front() << "\t入队队尾元素:" << v.back() << endl;
}
cout << "———————— 出队元素 ——————————" << endl;
/*** 3.出队数据:1,2,3,4,5,6 *****/
while(v.size() != 0)
{
cout << "出队队头元素:" << v.front() << "\t出队队尾元素:" << v.back() << endl;
v.pop(); /*出队*/
}
/*** 4.判断队列是否为空 ****/
cout << "队列是否为空:" << (v.empty() == true ? "为空" : "非空") << endl;
}
int main()
{
test0();
test1();
return 0;
}
2.pair (键值对 iostream 里面自带的)
构造函数: pair
输出模式: v.first, v.second
代码:
#include
using namespace std;
/********** pair 键值对 ***********
*
* 类使用: pair
* 成员:
template
struct pair
{
pair(_T1 key,_T2 value):first(key),second(value){} //构造函数
typedef _T1 first_type; /// @c 第一个元素的类型:主键
typedef _T2 second_type; /// @c 第二个元素的类型:数值
_T1 first; /// @c 第一个元素的值:主键值
_T2 second; /// @c 第二个元素的值:value值
};
********************************/
//模仿 pair 类
template
struct my_pair
{
/** 默认权限是 公有权限 **/
my_pair(_T1 key,_T2 value):first(key),second(value){} //构造函数
typedef _T1 first_type; // @c 第一个元素的类型:主键
typedef _T2 second_type; // @c 第二个元素的类型:数值
/*** 主要学习: first , second ***/
_T1 first; // @c 第一个元素的值:主键值
_T2 second; // @c 第二个元素的值:value值
};
int main()
{
/***** 案例: 主键:学号, 值:学生姓名 *******/
my_pair v(1000,"张三");
cout << "主键:" << v.first << "\t值:" << v.second << endl;
/***** 标准的键值对 ****/
pair v1(1001,"李四");
cout << "主键:" << v1.first << "\t值:" << v1.second << endl;
/***** 主要解决 一个参数无法操作的内容,例如 返回值类型只允许一个返回值,但是项目需要返回两个甚至
* 多个,所以可以使用键值对实现方案 ****************/
return 0;
}
3.set (集合 不可重复) /multiset(数据可重复存储)
/************* set 容器 ******************
* 特点:
* 1.去除重复值
* 2.插入时自动排序
* 3.容器内部元素插入时为常对象 - 只能访问常函数
* (自身就是key主键,主键不能修改)
* 4. set容器无法修改内部元素值
* **************************************/
构造函数: set
增加数据: v.insert(111);
查询数据: v.find(111);
统计set 容器元素个数 : v.count();
容器是否为空 : v.empty();
clear(); //清除所有元素
erase(pos); //删除pos迭代器所指的元素,返回下一个元素的迭代器
erase(beg, end); //删除区间(beg, end)的所有元素,返回下元素的迭代器
erase(elem); //删除容器中值为elem的元素。
代码:
#include
#include /*set集合容器*/
#include /*单端数组容器*/
using namespace std;/*标准命名空间*/
#define ADDR_SIZE(x) (sizeof(x)/sizeof(x[0])) //求取元素个数
/************* set 容器 ******************
* 特点:
* 1.去除重复值
* 2.插入时自动排序
* 3.容器内部元素插入时为常对象 - 只能访问常函数
* (自身就是key主键,主键不能修改)
* **************************************/
void test0()
{
set v;
int addr[] = {1,6,78,23,5,45,2,5}; /*无序数组*/
cout << "***** 插入数据 **** " << endl;
pair::iterator, bool> pair_set;
for(size_t i = 0; i < ADDR_SIZE(addr);i++)
{
pair_set = v.insert(addr[i]); /*插入数据*/
if(pair_set.second == true)
{
cout << "插入成功:" << *pair_set.first << endl;
}
else
{
cout << "插入失败:" << addr[i] << endl;
}
}
cout << "***** 打印set数据 ********" << endl;
set::iterator it;
for(it = v.begin(); it != v.end() ; it++)
{
cout << *it << ",";
}
cout << endl;
cout << "***** 试图去修改set容器元素值 ******" << endl;
it = v.begin(); /*第一元素*/
cout << "第一个元素:" << *it << endl;
// *it = 500; set容器无法修改内部元素值
cout << "***** 容器大小和判断是否为空 *****" << endl;
cout << "当前元素个数:" << v.size() << endl;
cout << "当前容器是否为空:" << (v.empty() == true ? "为空" : "非空") << endl;
cout << "***** 容器查找和统计元素 ******" << endl;
it = v.find(7);
if(it != v.end())
{
cout << "找到了元素为:" << *it << endl;
}
else
{
cout << "容器内没有找到为7的元素" << endl;
}
int num = v.count(5);
cout << "统计容器内元素为5的个数:" << num << endl;
}
/************* multiset 容器 ******************
* 特点:
* 1.插入时自动排序
* 2.容器内部元素插入时为常对象 - 只能访问常函数
* (自身就是key主键,主键不能修改)
* **************************************/
void test1()
{
multiset v;
int addr[] = {1,6,78,23,5,45,2,5}; /*无序数组*/
cout << "***** 插入数据 **** " << endl;
multiset::iterator it;
#if 0 //插入
for(size_t i = 0; i < ADDR_SIZE(addr);i++)
{
it = v.insert(addr[i]); /*插入数据*/
}
#else
vector v_vector;
for(size_t i = 0; i < ADDR_SIZE(addr);i++)
{
v_vector.push_back(addr[i]);
}
cout << "vector的数据:" << endl;
for(int i = 0; i< v_vector.size() ;i++)
{
cout << v_vector[i] << ",";
}
cout << endl;
v.insert(v_vector.begin(),v_vector.end());
#endif
cout << "***** 打印set元素 ****" << endl;
for(it = v.begin() ; it != v.end() ;it++)
{
cout << *it << ",";
}
cout << endl;
#if 1
v_vector.assign(v.begin(),v.end());
cout << "vector的数据:" << endl;
for(int i = 0; i< v_vector.size() ;i++)
{
cout << v_vector[i] << ",";
}
cout << endl;
#endif
cout << "***** 试图去修改set容器元素值 ******" << endl;
it = v.begin(); /*第一元素*/
cout << "第一个元素:" << *it << endl;
// *it = 500; set容器无法修改内部元素值
cout << "***** 容器大小和判断是否为空 *****" << endl;
cout << "当前元素个数:" << v.size() << endl;
cout << "当前容器是否为空:" << (v.empty() == true ? "为空" : "非空") << endl;
cout << "***** 容器查找和统计元素 ******" << endl;
it = v.find(7);
if(it != v.end())
{
cout << "找到了元素为:" << *it << endl;
}
else
{
cout << "容器内没有找到为7的元素" << endl;
}
int num = v.count(5);
cout << "统计容器内元素为5的个数:" << num << endl;
}
int main()
{
test1();
return 0;
}
4.map(地图) /multimap(可重复 地图)
/*********** map容器 ************
* 特点:
* 1.去除重复的主键
* ****************************/
构造函数 ; map
增加数据 : v.insert(pair
v[键值]= value; ==> v[1]="aaaa" (修改,可以通过主键修改value值(①存在则修改②不存在则插入)
删除数据:
clear(); //清除所有元素
erase(pos); //删除pos迭代器所指的元素,返回下一个元素的迭代器
erase(beg, end); //删除区间(beg, end)的所有元素,返回下元素的迭代器
erase(键值); //删除容器中值为 键值 的元素。
代码:
#include
#include
5.set 和 map
代码:
#include
/***** 这两个容器底层都是使用 二叉树实现 *****
* 1.自动排序
* 2.使用二分法方式
* 3.是数组和链表的折中方案
* *************************************/
#include /*集合容器*/
#include
6. 新学的内容 (json )(它的作用还不知道)
JSON(JavaScript Object Notation, JS对象简谱)是一种轻量级的数据交换格式。它基于 ECMAScript(European Computer Manufacturers Association, 欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。
了解连接 : JSON_百度百科 (baidu.com)
在线格式JSON:Json在线格式化工具-Json解析视图查看器-Json在线解析格式化工具 (jsons.cn)
代码:
#include
#include
#include
using namespace std;
#include "json/json.h" /* 引入json 头文件 */
using namespace Json;
int main()
{
/*** 定义一个 json 对象 ****/
Json::Value value;
/*** 没有则增加,有则修改 ****/
value["姓名"] = "王廷胡";
value["年龄"] = 18;
value["性别"] = "男";
value["身高"] = 165;
value["家庭"] = "和睦";
/***** value 转 基础类型 *****/
cout << "姓名:" << value["姓名"].asString() << endl;
cout << "年龄:" << value["年龄"].asInt() << endl;
cout << "家庭:" << value["家庭"].asCString() << endl;
/**** value 输出 *****/
cout << value << endl;
/**** value 转格式化 C 或 C++ *******/
string str_json = value.toStyledString();
cout << str_json << endl;
const char *C_json = str_json.data();
cout << str_json << endl;
#if 0
fstream fp;
fp.open("test.json",ios_base::trunc | ios_base::out | ios_base::in);
if(fp.is_open() == false) return -1;
fp.write(C_json,strlen(C_json));
fp.close();
#else
fstream fp;
fp.open("test.json",ios_base::out | ios_base::in);
if(fp.is_open() == false) return -1;
string str;
char ch;
while(fp.eof() != true)
{
ch = fp.get();
str += ch;
}
cout << "str = " << str << endl;
/***** 将string 或 char * 转为 JSON的Value ******/
Reader json_Read;
Value json_value;
#if 1 /* C++的string 风格 */
json_Read.parse(str,json_value);
#else /* C语言的char *风格 */
json_Read.parse("{\"姓名\":\"李白\"\"}",json_value);
#endif
cout << "姓名:" << json_value["字符集"]["GBK"] << endl;
#endif
return 0;
}
资源里面有 json 资源
linux 视屏监控
代码:
main.cpp
// #include "cv.h"
// #include "highgui.h"
#include "opencv2/core/core.hpp" /* 引入opencv核心库 -lopencv_core */
#include "opencv2/highgui/highgui.hpp" /*图像处理库 -lopencv_highgui */
#include "opencv2/imgproc/imgproc.hpp" /*摄像头库 -lopencv_imgproc */
using namespace cv; /*引入 OPencv 命名空间 */
int main(int, char**)
{
VideoCapture cap(0); /*实例化摄像头 对象 依赖于 0号摄像头 */
if(!cap.isOpened()) return -1;/*打开0号摄像头*/
Mat frame, edges; /*实例化两个图片对象 frame , edges */
namedWindow("edges",1);/*创建窗体 名称为 edges */
for(;;)
{
cap >> frame; /*摄像头拍照 结果写入 frame 图片对象 */
edges = frame;
// cvtColor(frame, edges, CV_BGR2GRAY); /*灰度处理*/
// GaussianBlur(edges, edges, Size(7,7), 1.5, 1.5);/*高斯模糊*/
// Canny(edges, edges, 0, 30, 3);/*边缘检测*/
imshow("edges", edges);
if(waitKey(30) >= 0) break;
}
return 0;
}
makefile
#源文件
SOURCES += main.cpp
#编译标志
CONFIG += -std=c++11
CONFIG += -g
#链接库
CONFIG += -lopencv_core -lopencv_highgui -lopencv_imgproc
#编译器
CC = g++
#应用名称
APP = a.out
#编译
${APP}:${SOURCES}
${CC} $^ ${CONFIG} -o $@
clean:
rm -rf ${APP}
在相对应的目录下,输入命令:
1. makefile
2. ./a.out
就可以了
有些地方要注意: