C++与算法有关的库(初学者)

1、《cstring》
1.1strlen()字符串长度
1.2strcmp()字符串比较
1.3strcmp()字符串拷贝
1.4memset()暴力清空

char str[10]; memset(str,0,sizeof(str));

1.5memcpy()暴力拷贝
2、《cstdlib》
2.1qsort()快排序
2.2rand()随机数
2.3malloc()free()动态分配内存
3、《ctime》
3.1time(0)1970年到截止的秒数
3.2clock()程序启动到目前的毫秒数
4、《cctype》
4.1isdigit()判断是数字
4.2isalpha()判断是字母
5、《algorithm》
5.1nth_element()该函数是对范围内的元素进行二分排序,以nth为分界点,前面的都比nth小,后面的都比nth大,但是只是对前半部和后半部都不会严格排序。
5.2unique()切记,没有排序前只是去掉相邻的重复元素,如果要真正去重就要排序

 sort(arr.begin(), arr.end());
 int n=unique(arr.begin(),arr.end())-arr.begin();

5.3 lower_bound()
lower_bound的返回值减去数组的地址就是
要查找的元素在数组中的位置。
第一个大于等于的数

sort(arr.begin(), arr.end());
int n=lower_bound(arr.begin(), arr.end(),1)-arr.begin();

upper_bound()第一个大于的数
6、queue()
普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除。
priority_queue()他和queue不同的就在于我们可以自定义其中数据的优先级, 让优先级高的排在队列前面,优先出队。
7、set
set,有序集合
unordered_set()无序集合,但是可以O1时间插入和访问一个数
8、细节
8.1 1s约等于1e8运算
8.2 G++在输出double时,用%lf会WA到哭,用%f
8.3 数据范围及数据结果均在1e9以内时,可以令const int INF =0x3f3f3f3f表示无穷大值,比且可以用memset(arr,INF,sizeof(arr))来令数组初始化无穷大。

最后,参考在这里插入图片描述
学长经验: 清楚自己想要达到的水平,不要妄自菲薄,不要骄傲自大
合理利用一切资源:搜索引擎、词典、好的教材、ppt、博客、一个好的编辑器、同学和学长。
其他方法都用尽饿情况下,再去搜索题解,最后再向别人提问。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
OpenSAL1.1 包含了算法导论中所有数据结构算法以及其他内容,本资源为该算法的静态链接 内容如下(*号表示1.1版本新增内容): 数据结构:一般堆、二项堆、斐波那契堆、红黑树、通用散列(采用全域散列和完全散列技术)、不相交集合、任意维数组、高维对称数组。 图论算法(兼容有向图,无向图):广度和深度优先遍历、确定图是否存在回路、拓扑排序、强连通分支、欧拉环(欧拉路径)、最小生成树(Kruskal、Prim)、单源最短路径(3种)、每对顶点间最短路径(2种)、最大流(2种)等等。 代数算法:霍纳法则计算多项式和、矩阵乘法(2种)、方阵的LUP分解、解线性方程组(2种)、矩阵求逆(2种)、求伪逆矩阵(2种)、解正态方程组(2种)、最小二乘估计(2种)、多元最小二乘估计*、快速傅里叶变换、快速傅里叶逆变换、多维快速傅里叶变换、多维快速傅里叶逆变换、快速向量求卷积(单变量多项式乘积)、快速张量求卷积(多变量多项式乘积)、多项式除法*、快速方幂和算法。 序列算法:最长公共子序列、KMP序列匹配*、键值分离排序。 数论算法:大数类(兼容浮点数、整数、与内置类型兼容运算)*、RSA加解密系统*、解同余方程*、孙子定理解同余方程组*、Miller_Rabin素数测试(产生大质数)*、随机数(实数、大数)*、欧几里得算法*。 计算几何算法:确定任意一对线段是否相交*、凸包*、最近点对*。 运筹学:线性规划(单纯形法)*、分配问题*、最优二度子图*、多01背包问题*
OpenSAL1.1 包含了算法导论中所有数据结构算法以及其他内容,本资源为该算法的动态链接 内容如下(*号表示1.1版本新增内容): 数据结构:一般堆、二项堆、斐波那契堆、红黑树、通用散列(采用全域散列和完全散列技术)、不相交集合、任意维数组、高维对称数组。 图论算法(兼容有向图,无向图):广度和深度优先遍历、确定图是否存在回路、拓扑排序、强连通分支、欧拉环(欧拉路径)、最小生成树(Kruskal、Prim)、单源最短路径(3种)、每对顶点间最短路径(2种)、最大流(2种)等等。 代数算法:霍纳法则计算多项式和、矩阵乘法(2种)、方阵的LUP分解、解线性方程组(2种)、矩阵求逆(2种)、求伪逆矩阵(2种)、解正态方程组(2种)、最小二乘估计(2种)、多元最小二乘估计*、快速傅里叶变换、快速傅里叶逆变换、多维快速傅里叶变换、多维快速傅里叶逆变换、快速向量求卷积(单变量多项式乘积)、快速张量求卷积(多变量多项式乘积)、多项式除法*、快速方幂和算法。 序列算法:最长公共子序列、KMP序列匹配*、键值分离排序。 数论算法:大数类(兼容浮点数、整数、与内置类型兼容运算)*、RSA加解密系统*、解同余方程*、孙子定理解同余方程组*、Miller_Rabin素数测试(产生大质数)*、随机数(实数、大数)*、欧几里得算法*。 计算几何算法:确定任意一对线段是否相交*、凸包*、最近点对*。 运筹学:线性规划(单纯形法)*、分配问题*、最优二度子图*、多01背包问题*
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

.0-0.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值