【c++语法】位运算与常用库函数
2022/1/17 14:03:42
本文主要是介绍【c++语法】位运算与常用库函数,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
位运算
& 与
| 或
~ 非
^ 异或
>> 右移
<< 左移
常用操作:
(1) 求x的第k位数字 x >> k & 1
(2) lowbit(x) = x & -x,返回x的最后一位1 (其中-x = ~x + 1)
int a = 2; cout << (a & -a) << endl; // 2 int a = 12; cout << (a & -a) << endl; // 4
更多操作: 位运算技巧
常用库函数
基本都在
#include <algorithm>
reverse
翻转
reverse(a.begin(), a.end()); // 翻转一个vector reverse(a, a + n); // 翻转一个数组
unique
去重(需保证相同元素挨边)
返回去重之后的尾迭代器(或指针),仍然为前闭后开,即这个迭代器是去重之后末尾元素的下一个位置。
该函数常用于离散化,利用迭代器(或指针)的减法,可计算出去重后的元素个数。
int m = unique(a.begin(), a.end()) – a.begin(); // 把一个vector去重 int m = unique(a, a + n) – a; // 把一个数组去重,元素存放在下标1~n // 顺带删除 vector 后面的数 a.erase(unique(a.begin(), a.end()), a.end());
random_shuffle
随机打乱
#include <ctime> // 初始化随机种子 srand(time(0)); random_shuffle(a.begin(), a.end());
sort
对两个迭代器(或指针)指定的部分进行快速排序。可以在第三个参数传入定义大小比较的函数,或者重载“小于号”运算符。
// 从小到大 sort(a.begin(), a.end()); // 从大到小 sort(a.begin(), a.end(), greater<int>()); // 自定义 bool cmp(int a, int b) { // a 是否应该在 b的前面 return a < b; } sort(a.begin(), a.end(), cmp); // sort函数的cmp必须只能是>或者<。
lower_bound/upper_bound
lower_bound 的第三个参数传入一个元素x,在两个迭代器(指针)指定的部分上执行二分查找,返回指向第一个大于等于x的元素的位置的迭代器(指针)。
upper_bound 的用法和lower_bound大致相同,唯一的区别是查找第一个大于x的元素。
当然,两个迭代器(指针)指定的部分应该是提前排好序的。
int a[] = {1,2,3,4,5}; int *p = lower_bound(a, a + 5, 3); cout << *p << endl; vector<int> a{1,2,3,4,5}; cout << lower_bound(a.begin(), a.end(), 4) - a.begin();
关于cctype头文件里的一些函数
// 判断一个字符是否是字母 A-Z、a-z isalpha(c); // 类似的有 islower(c); isupper(c); isalnum(c); // 字母大写小写+数字 isblank(c); // space和\t isspace(c); // space、\t、\r、\n // 转换字符大小写 tolower(c); toupper(c);
这篇关于【c++语法】位运算与常用库函数的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用
- 2025-01-03混合搜索:用LanceDB实现语义和关键词结合的搜索技术(应用于实际项目)
- 2025-01-03停止思考数据管道,开始构建数据平台:介绍Analytics Engineering Framework
- 2025-01-03如果 Azure-Samples/aks-store-demo 使用了 Score 会怎样?
- 2025-01-03Apache Flink概述:实时数据处理的利器