C++各个版本新增对于算法竞赛有用特性

news/2024/4/27 10:03:33/文章来源:https://www.cnblogs.com/Cattle-Horse/p/16636208.html

C++各个版本新增对于算法有用特性

C++11

auto与decltype类型推导(摘自程序喵大人)

auto

auto可以让编译器在编译器就推导出变量的类型,话不多说上代码:

auto a = 10; // 10是int型,可以自动推导出a是int
int i = 10;auto b = i; // b是int型
auto d = 2.0; // d是double型

这就是auto的基本用法,可以通过=右边的类型推导出变量的类型。

<font size=3auto推导规则

直接看代码

代码1:

int i = 10;auto a = i, &b = i, *c = &i; // a是int,b是i的引用,c是i的指针,auto就相当于intauto d = 0, f = 1.0; // error,0和1.0类型不同,对于编译器有二义性,没法推导auto e; // error,使用auto必须马上初始化,否则无法推导类型

代码2:

void func(auto value) {} // error,auto不能用作函数参数
class A {    auto a = 1; // error,在类中auto不能用作非静态成员变量    static auto b = 1; // error,这里与auto无关,正常static int b = 1也不可以    static const auto int c = 1; // ok};
void func2() {    int a[10] = {0};    auto b = a; // ok    auto c[10] = a; // error,auto不能定义数组,可以定义指针    vector<int> d;    vector<auto> f = d; // error,auto无法推导出模板参数}

auto的限制:

  • auto的使用必须马上初始化,否则无法推导出类型
  • auto在一行定义多个变量时,各个变量的推导不能产生二义性,否则编译失败
  • auto不能用作函数参数
  • 在类中auto不能用作非静态成员变量
  • auto不能定义数组,可以定义指针
  • auto无法推导出模板参数

再看这段代码:

int i = 0;auto *a = &i; // a是int*auto &b = i; // b是int&auto c = b; // c是int,忽略了引用
const auto d = i; // d是const intauto e = d; // e是int
const auto& f = e; // f是const int&auto &g = f; // g是const int&

首先,介绍下,这里的cv是指const 和volatile

推导规则

  • 在不声明为引用或指针时,auto会忽略等号右边的引用类型和cv限定
  • 在声明为引用或者指针时,auto会保留等号右边的引用和cv属性

decltype

上面介绍auto用于推导变量类型,而decltype则用于推导表达式类型,这里只用于编译器分析表达式的类型,表达式实际不会进行运算,上代码:

int func() { return 0; }decltype(func()) i; // i为int类型
int x = 0;decltype(x) y; // y是int类型decltype(x + y) z; // z是int类型

注意:decltype不会像auto一样忽略引用和cv属性,decltype会保留表达式的引用和cv属性

cont int &i = 1;int a = 2;decltype(i) b = 2; // b是const int&

decltype推导规则

对于decltype(exp)有

  • exp是表达式,decltype(exp)和exp类型相同
  • exp是函数调用,decltype(exp)和函数返回值类型相同
  • 其它情况,若exp是左值,decltype(exp)是exp类型的左值引用
int a = 0, b = 0;decltype(a + b) c = 0; // c是int,因为(a+b)返回一个右值decltype(a += b) d = c;// d是int&,因为(a+=b)返回一个左值
d = 20;cout << "c " << c << endl; // 输出c 20

auto和decltype的配合使用

auto和decltype一般配合使用在推导函数返回值的类型问题上。

下面这段代码

template<typename T, typename U>return_value add(T t, U u) { // t和v类型不确定,无法推导出return_value类型    return t + u;}

上面代码由于t和u类型不确定,那如何推导出返回值类型呢,我们可能会想到这种

template<typename T, typename U>decltype(t + u) add(T t, U u) { // t和u尚未定义    return t + u;}

这段代码在C++11上是编译不过的,因为在decltype(t +u)推导时,t和u尚未定义,就会编译出错,所以有了下面的叫做返回类型后置的配合使用方法:

template<typename T, typename U>auto add(T t, U u) -> decltype(t + u) {    return t + u;}

返回值后置类型语法就是为了解决函数返回值类型依赖于参数但却难以确定返回值类型的问题。

std::array

提要

数组,在越界访问时抛出异常,建议使用std::array替代普通的数组

在声明时需要提供数据类型及元素个数(常量)

example

std::array<int,10> a或者constexpr int n=10; std::array<int,n> a

std::tuple

提要

元组类型,与pair相似

example

// 1.初始化列表tuple<int, double, string> t1(1, 13.1, "wdnmd");// 2.使用 tuple 头文件中辅助函数 make_tuple() 生成tuple 对象tuple<int, float, char> t2 = make_tuple(2, 15.6f, 'a');// 3.花括号推导类型初始化(since C++17)tuple t{1, 2ll, "wdnmd", 'c'};// 4.使用std::get<lth>(obj)来获取tuple内的值cout << std::get<0>(t1) << ' ' << std::get<1>(t1) << ' ' << std::get<2>(t1) << endl;// 5.得到元素个数//   1. std::tuple_size< >::value (since C++11)//   2. std::tuple_size_v< >      (since C++17)cout << std::tuple_size<decltype(t1)>::value << ' ' << std::tuple_size_v<decltype(t1)> << endl;// 6.得到元素类型//   1.std::tuple_element<1, decltype(t1)>::type (since C++11)//   2.std::tuple_element_t<1, decltype(t1)>     (since C++17)//   3.auto (since C++11)std::tuple_element<1, decltype(t1)>::type a = std::get<1>(t1);std::tuple_element_t<1, decltype(t1)> b = std::get<1>(t1);auto c = get<1>(t1);

std::unordered_set与std::unordered_map

提要

基于hash表实现的set和map,内部不会排序,使用方法与set和map类似

由于内部不是有序的所以无lowerbound等函数

一些算法

提要

  1. all_of:检测表达式是否对范围[first, last)中所有元素都返回true,如果都满足,则返回true
  2. any_of:检测表达式是否对范围[first, last)中至少一个元素返回true,如果满足,则返回true,否则返回false
  3. none_of:检测表达式是否对范围[first, last)中所有元素都不返回true,如果都不满足,则返回true,否则返回false
  4. find_if_not和find_if:返回第一个不符合要求 / 符合要求的元素迭代器
  5. copy_if:复制满足条件的元素
  6. iota:对容器内的元素按序递增赋值
  7. min_element和max_element:返回容器内最大元素和最小元素迭代器
  8. is_sorted:检测容器内是否已经排好序(默认升序),如果是,则返回true,否则返回false
  9. is_sorted_unitl:返回第一个不满足规定序(默认升序)的元素的迭代器

example

	vector<int> a(6);iota(a.begin(), a.end(), 2);  //对a内元素从2赋值 (2,3,4,5,6,7)//检测a内元素是否均为奇数                        (输出false)cout << all_of(a.begin(), a.end(), [](const int& i) { return i % 2; }) << endl;//检测a内元素是否有一个为奇数                    (输出true)cout << any_of(a.begin(), a.end(), [](const int& i) { return i % 2; }) << endl;//检测a内元素是否均不为为奇数                    (输出false)cout << none_of(a.begin(), a.end(), [](const int& i) { return i % 2; }) << endl;//返回第一个不符合要求的元素迭代器                (输出2)cout << *find_if_not(a.begin(), a.end(), [](const int& i) { return i % 2; }) << endl;//返回第一个符合要求的元素迭代器                  (输出3)cout << *find_if(a.begin(), a.end(), [](const int& i) { return i % 2; }) << endl;//返回容器内最大的元素的迭代器                    (输出7)cout << *max_element(a.begin(), a.end()) << endl;//返回容器内最小的元素的迭代器                    (输出2)cout << *max_element(a.begin(), a.end()) << endl;//检测容器内是否已经排好序(默认升序)/*(输出true)*/ cout << is_sorted(a.begin(), a.end()) << endl;/*(输出false)*/ cout << is_sorted(a.begin(), a.end(), [](const int& a, const int& b) { return a > b; }) << endl;//返回第一个不满足规定序(默认升序)的元素的迭代器  (返回a.end()迭代器)is_sorted_until(a.begin(), a.end());

C++14

对auto类型推导进行了优化

lambda可以像模板那样使用了

auto f = [] (auto a) { return a; };
cout << f(1) << ' '<< f(2.3f) << endl;

二进制字面量及分隔符

C++14引入了二进制字面量,也引入了分隔符,防止看起来眼花

	int a = 0b11;  // a = 3double b = 3.14'1234'1234'1234;

参考链接

一文吃透C++11中auto和decltype知识点 (程序喵大人)

c++11新特性,所有知识点都在这了!( 程序喵大人)

C++14新特性的所有知识点全在这儿啦!(程序喵大人)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_2936.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

js实现幻灯片

使用原生js实现轮播图 html代码<div class="slide"><ul><li style="display: block;"><img src="1.jpg"></li><li><img src="2.jpg"></li><li><img src="3.jpg"&…

字节跳动基于 ClickHouse 优化实践之“查询优化器”

更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群 相信大家都对大名鼎鼎的 ClickHouse 有一定的了解了,它强大的数据分析性能让人印象深刻。但在字节大量生产使用中,发现了 ClickHouse 依然存在了一定的限制。例如:缺少完整的 upsert…

echarts-dataset数据源配置项

如下效果图: 代码入下:let box4 = document.querySelector(.box4)let myCharts3 = echarts.init(box4)myCharts3.setOption({dataset:{// 二维数组存放数据source:[// 0 1 2 3 4 5 六个维度[衣服,22,15,36,35,18],[食品,60,39,50,15,22],[生活用品,60,52,36,15…

RN 调试

使用前先关闭debugger模式关闭谷歌,在打开调试工具,然后再打开debugger 1.使用谷歌浏览器来调试不能查看标签结构不能查看网络请求 2.使用rn推荐的工具react-native-debugger来调试https://github.com/jhen0409/react-native-debugger/releases可以查看标签结构不能查看网络请…

Excel聚光灯设置

1.同时按住 ALT+F11进入vba 2.双击要设置的sheet页 3.输入以下代码Private Sub Worksheet_SelectionChange(ByVal Target As Range)Cells.Interior.ColorIndex = xlNoneTarget.EntireRow.Interior.ColorIndex = 24Target.EntireColumn.Interior.ColorIndex = 24End Sub4.效果如…

【三维地图】开发攻略 —— 详解“GeoJSON”技术和应用场景

GeoJSON ,一个用于存储地理信息的数据格式。GoeJSON对象可以表示几何、特征或特征集合,支持:点、线、面、多点、多线、多面和几何集合。在基于平面地图,三维地图中都需要用到的一种数据类型。 由于这种格式在三维地图中的优秀属性,使用它我们不仅可以轻松实现地图类功能,…

JavaScript设计模式及代码实现——单例模式

单例模式1 定义保证一个类仅有一个实例,并提供一个访问它的全局访问点。2 应用时机当一个类的实例被频繁使用,如果重复创建这个实例,会无端消耗资源。比如 dialog 弹窗会被全局重复使用 业务功能本身决定了全局只能有唯一的实例。比如 redux 管理的数据,只能有唯一的一份3 …

ubuntu18.04屏幕录制Vokoscreen

Vokoscreen 可被视为具有良好分类菜单的简单屏幕录制机的更好 UI 版本。- 除了在simplescreenrecorder中包含的所有功能,Vokoscreen 还支持外部网络摄像头以及内置网络摄像头。 然而,它不支持在simplescreenrecorder中可用的 JACK 音频。 下载命令:sudo apt install vokoscr…

磁共振成像原理

目录1. 原子核的自旋2. 进动3. 磁共振现象4. 射频脉冲1. 原子核的自旋 原子有原子核和绕核运动的电子组成。 原子核的自旋:质子数和中子数一个为奇数、一个为偶数; 两者都为奇数这两种情况的原子核就会自旋。原子核是带正电,绕自旋轴旋转,效应相当于环形电流,周围会产生磁…

业务流程可视化-让你的流程图Run起来(7.运行状态持久化轻量工作流支持)

前言 感谢大家阅读本项目系列文章和对项目的支持。分享一下我对这个项目的新的改进。 之前项目做到了流程设计可视化和流程运行结果可视化。 本期发布的版本中实现了中间的运行过程的实时可视化,和流程状态持久化问题。 大家可以根据项目提供的接口自由扩展自己的工作流实现。…

DataGrip连接Mysql报08S01解决方案

以前正常使用的GataGrip,突然在某天报下面的错误提示:08S01 [08S01]Communications link failureThe last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. No appropriate protocol (protocol is…

数据结构面试总结【第一弹】

数据结构面试总结 目录数据结构面试总结1.数据结构基本概念1.1 数据结构三要素2.线性表2.1 数组与链表有什么关系2.2 线性表的存储结构2.3 头指针和头节点的区别2.4 栈和队列的区别3.树3.1 度数为2的树与二叉树有什么区别3.2 唯一确定一棵二叉树3.3 二叉排序树3.4 最小生成树有…

优爱酷模拟点击自动翻页_自动展开所有批量网页转mhtml单网页保存

优爱酷模拟点击自动翻页_自动展开所有批量网页转mhtml#涨知识# 终于可以解放双手了! 1、页面有很多“折叠”的需要“展开”的内容,例如:点击查看全文,展开 等的网页,1个还好,多个“展开”如何解决?如果能#自动展开#岂不美哉? 2、普通网页翻页后链接会变化成不一样的,遇…

Ps 2022在M1 mac上导出 PNG 格式发生未知错误如何解决?

Photoshop 2022 for mac 在M1上导出 PNG 时,会提示“发生了未知错误”,即使点击“导出”按钮,导出的图片也是一个空白文件。小编教给大家 Ps 2021在 M1 mac上导出 PNG 格式发生未知错误的解决方法。1.打开 PhotoShop 的首选项 >常规,如下图所示:(也可以通过快捷键 Com…

图数据库入门教程(二)认识tinkerpop与gremlin

上一篇文章我们对图数据库有了一个简单的理解,对于关系的计算优雅而快速,适用与一些关系计算的场景,比如社交网络、金融反欺诈、商机发现、智能推荐等,想了解更多可以看一下阿里云gdb的文档https://help.aliyun.com/document_detail/112465.html。 当前图数据库天下的形式 …

设计模式之(3)——抽象工厂方法模式

定义:抽象工厂模式简单地讲,就是提供一个超级工厂,围绕这个超级工厂创建其他工厂;抽象工厂模式提供一个创建一些列相关或者相互依赖对象的接口;在此之前我们先来讲一下产品等级和产品族的概念;相同的产品等级就是相同的同一类的产品,比如美的冰箱、格力冰箱、海尔冰箱,…

Mysql----事务

《需求》 《操作》 《细节》

分类数据展示功能_缓存优化_分析

分类数据展示功能_缓存优化_分析 对数据进行一个缓存优化,分析发现:分类的数据在每一次页面加载后会重新请求数据库来加载,对数据库的压力比较大,而且这数据不会经常发送变化,可使用redis来缓存这个数据 分类数据展示功能_缓存优化_代码实现public class CategoryServiceI…

日常问题: 上线确认

作为开发,手头没事的时候,担心自己没参与大项目,年终没产出。而真正需求到来的时候,却是狂风暴雨一般,密集且时间紧迫。在紧锣密鼓996之后,终于迎来了上线。 但这一天不太顺利。背景 xxx正式上线。上线前,方案强调要开发把所有配置都给到他,他要确认下。当时觉得有问题…

第一个代码Hello World!

HelloWorld新建一个文件夹,存放代码新建一个Java文件 文件后缀为.java名为Hello.java[注意]要显示系统后缀名编写代码 public class Hello{ public static void main(String[] arge){ System.out.print("Hello,World!"); }} 打开cmd 路径需要是Hello.j…