C++编程和STL

简介: C++广泛用于竞争性编程。由于其可靠性、高效执行、短片段等,它是首选。它已被大多数编码人员适应,因为它还提供了标准模板库(STL)的好处。

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第3天,点击查看活动详情


C++广泛用于竞争性编程。由于其可靠性、高效执行、短片段等,它是首选。它已被大多数编码人员适应,因为它还提供了标准模板库(STL)的好处。


C++ STL是编程的支柱。内置函数有时会将代码片段减少到一行。因此,以下是有关C++标准模板库(STL)的一些有趣事实:


1) 值可以通过一对{} 分配给容器。

// 按对分配值的各种方法
// 方法1
pair<int, int> p = make_pair(3, 4);
// 方法2
pair<int, int> p = { 3, 4 };
// 方法3
pair<int, <char, int> > p = { 3, { 'a', 10 } };
复制代码


2) 正如我们熟悉的这对,还有一种称为 元组 的东西。

// 元组可以包含不同类型的元素
tuple t = {3, 4, 5, 'a'};
复制代码

 


3) 我们可以避免写入所有头文件,例如iostream,vector,string,math等。只包含一个头文件就可以完成了这项工作!


头文件是 <bits/stdc++.h>。

#include<bits/stdc++.h>
using namespace std;
复制代码


4) 你不需要为 GCD 函数编写欧几里得算法,相反,我们可以使用 __gcd(值 1, 值 2)。此函数返回两个数字的最大公约数。

Example: __gcd(18, 45) = 9
复制代码
// 演示GCD功能的CPP程序
#include <bits/stdc++.h>
using namespace std;
int main()
{
  int r = __gcd(10, 15);
  cout << r;
  return 0;
}
复制代码


输出

5
复制代码

注意: 这仅适用于 GCC。


5) 在C++中,您可以使用“to_string();” 命令直接将整数转换为字符串。

// CPP程序演示to_string()函数的功能
#include <bits/stdc++.h>
using namespace std;
// 驱动程序代码
int main()
{
  int a = 97;
  string t = to_string(a);
  cout << t;
}
复制代码


输出

97
复制代码

 


6) 在C++中,您可以使用 'stoi();  命令直接将字符串转换为整数。

// CPP程序演示stoi()函数的功能
#include <bits/stdc++.h>
using namespace std;
int main()
{
  string a = "2665";
  int t = stoi(a);
  cout<<t;
}
复制代码


输出

2665
复制代码


(七) 默认情况下,集合按升序存储元素。

set<datatype> setname;
复制代码

注意: set<datatype, greater> setname;用于按降序存储集合中的值。

 


8) 在函数外部声明的每个变量都是静态的,默认值为 0。

// CPP程序,用于演示函数外声明的变量是静态的,默认值为0
#include <bits/stdc++.h>
using namespace std;
int a[5];
int main()
{
  // []中的值为0
  for (int i = 0; i < 5; i++)
    cout << a[i] << " ";
  // b[]中的值是垃圾
  cout << endl;
  int b[5];
  for (int i = 0; i < 5; i++)
    cout << b[i] << " ";
  return 0;
}
复制代码


输出

0 0 0 0 0 
4196880 0 4196368 0 846571392 
复制代码

 


9) 如果你在函数中声明一个数组,它的元素值是垃圾,但要将所有元素的值设置为零,我们可以使用,


TYPE a[n] = { };
复制代码
// CPP程序,用于将函数中数组的所有元素的值设置为零
#include <bits/stdc++.h>
using namespace std;
int main()
{
  // []中的值为0
  int a[5] = {};
  for (int i = 0; i < 5; i++)
    cout << a[i] << " ";
  // b[]中的值是垃圾
  cout << endl;
  int b[5];
  for (int i = 0; i < 5; i++)
    cout << b[i] << " ";
  return 0;
}
复制代码


输出

0 0 0 0 0 
4196896 0 4196368 0 -345132736 
复制代码


10) 数字 x 的二进制表示中的设置位数可以通过 __builtin_popcountll(x)  找到。基本上,此函数计算整数中的 one(设置位)的数量。


// CPP程序演示__builtin_popcountll(x)的功能
#include <bits/stdc++.h>
using namespace std;
int main()
{
  int x = 5; // 0101
  cout << __builtin_popcountll(x);
  return 0;
}
复制代码


输出

2
复制代码

注意: 这仅适用于 GCC。

 


11) Memset 设置内存块的字节值(或无符号字符)。我们可以使用 memset 将整数数组的所有元素初始化为 0 或 -1,但不能初始化其他值。


初始化数组中除 0 或 -1 以外的所有元素不会根据需要设置所有元素,因为 memset 设置字节值,例如,调用 memset(arr, 1, 4) 来设置数组 int arr[4] 的所有元素。它变得0x01 0x01 0x01 0x01。(即 16,843,009,具体取决于您的 CPU 架构)但你的期望值是0x00 0x00 0x00 0x01。


// CPP程序演示memset将整数数组的所有元素初始化为0或-1
#include <bits/stdc++.h>
using namespace std;
int main()
{
  int a[5];
  // A的所有元素都是零
  memset(a, 0, sizeof(a));
  for (int i = 0; i < 5; i++)
    cout << a[i] << " ";
  cout << endl;
  // A的所有元素都是-1
  memset(a, -1, sizeof(a));
  for (int i = 0; i < 5; i++)
    cout << a[i] << " ";
  cout << endl;
  // 不起作用
  memset(a, 5, sizeof(a));
  for (int i = 0; i < 5; i++)
    cout << a[i] << " ";
}
复制代码


输出

0 0 0 0 0 
-1 -1 -1 -1 -1 
84215045 84215045 84215045 84215045 84215045 
复制代码


如果大家发现什么不正确的地方,或者你想分享有关上述的更多内容,可以在下面评论。



目录
相关文章
|
2天前
|
安全 前端开发 程序员
|
2天前
|
算法 安全 编译器
【C++】从零开始认识泛型编程 — 模版
泛型编程是C++中十分关键的一环,泛型编程是C++编程中的一项强大功能,它通过模板提供了类型无关的代码,使得C++程序可以更加灵活和高效,极大的简便了我们编写代码的工作量。
15 3
|
2天前
|
Java Linux 调度
|
2天前
|
设计模式 算法 C++
【C++】STL之迭代器介绍、原理、失效
【C++】STL之迭代器介绍、原理、失效
13 2
|
2天前
|
存储 C++ 容器
C++:STL - set & map
C++:STL - set & map
15 4
|
2天前
|
算法 安全 程序员
【C++】STL学习之旅——初识STL,认识string类
现在我正式开始学习STL,这让我期待好久了,一想到不用手撕链表,手搓堆栈,心里非常爽
16 0
|
2天前
|
安全 C++
C++多线程编程:并发与同步
C++多线程编程:并发与同步
10 0
|
2天前
|
存储 算法 编译器
C++的模板与泛型编程探秘
C++的模板与泛型编程探秘
11 0
|
2天前
|
存储 Serverless C++
【C++入门到精通】哈希 (STL) _ unordered_map _ unordered_set [ C++入门 ]
【C++入门到精通】哈希 (STL) _ unordered_map _ unordered_set [ C++入门 ]
10 1
|
2天前
|
存储 设计模式 算法
【C++/STL】stack和queue(容器适配器、优先队列、双端队列)
【C++/STL】stack和queue(容器适配器、优先队列、双端队列)
14 1