首页 > 编程语言 >准备蓝桥杯和ACM:C++标准库头文件及其常用功能简介

准备蓝桥杯和ACM:C++标准库头文件及其常用功能简介

时间:2024-09-28 17:21:26浏览次数:10  
标签:std main 头文件 int namespace C++ 蓝桥 using include

概述

        在C++编程中,标准库为开发者提供了丰富的工具和功能,使得代码更简洁、易于维护。本文将深入探讨一些常用的C++标准库头文件,如<iostream><algorithm><string>等,以及它们所提供的基本功能与常见用法。通过对这些头文件的理解和应用,开发者能够更加高效地进行程序设计和开发。

目录

概述

详解

#include

#include

#include

#include  

#include

#include

#include

using namespace std;

总结

1.

2.

3.

4.

5.

6.

7.

8. using namespace std;


详解

#include<iostream>

        #include <iostream> 是C++中用于包含iostream头文件的预处理指令。这个头文件提供了输入和输出流的基本功能,使得你可以使用 cin 和 cout 这两个流对象来进行控制台输入和输出。

以下是一些常见的用法:

1. 输出到控制台 (cout):

   #include <iostream>

   using namespace std;



   int main() {

       cout << "Hello, World!" << endl;

       return 0;

   }

   上述代码使用 cout 将字符串 "Hello, World!" 输出到控制台,并在末尾加上 endl 以换行。

2. 从控制台输入 (cin):
  

 #include <iostream>

   using namespace std;



   int main() {

       int x;

       cout << "Enter a number: ";

       cin >> x;

       cout << "You entered: " << x << endl;

       return 0;

   }

        上述代码使用 cin 从用户处接收输入,并将输入的整数存储在变量 x 中,然后将其输出到控制台。

3. 控制格式输出:

 #include <iostream>

   #include <iomanip>

   using namespace std;



   int main() {

       double pi = 3.141592653;

       cout << fixed << setprecision(2) << "Value of pi: " << pi << endl;

       return 0;

   }

  

        上述代码使用 fixed 和 setprecision 控制输出格式,将 pi 的值输出为小数点后两位。

        #include <iostream> 是C++标准库中的一部分,它包含了一些用于标准输入输出的基本工具,是C++程序中常见的头文件之一。


#include<algorithm>

        #include <algorithm> 是C++中用于包含 algorithm 头文件的预处理指令。这个头文件提供了一系列的算法,涵盖了很多常见的操作,例如排序、查找、删除等。以下是一些常见的算法及其用法:

1. 排序(Sort):

 #include <algorithm>

   #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector = {3, 1, 4, 1, 5, 9, 2, 6, 5};

       sort(myVector.begin(), myVector.end());  // 对容器进行升序排序



       // 现在 myVector 为 {1, 1, 2, 3, 4, 5, 5, 6, 9}

      

       return 0;

   }

2. 查找(Find):

   #include <algorithm>

   #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector = {3, 1, 4, 1, 5, 9, 2, 6, 5};

       auto it = find(myVector.begin(), myVector.end(), 4);  // 查找值为4的元素



       // 如果找到,it 指向找到的元素;如果没找到,it 等于 myVector.end()



       return 0;

   }

 

3. 最大值(Max):

  #include <algorithm>

   using namespace std;



   int main() {

       int a = 5, b = 8;

       int maxVal = max(a, b);  // 返回a和b中的最大值



       return 0;

   }

  

4. 最小值(Min):

#include <algorithm>

   using namespace std;



   int main() {

       int a = 5, b = 8;

       int minVal = min(a, b);  // 返回a和b中的最小值



       return 0;

   }

  

5. 反转(Reverse):

 #include <algorithm>

   #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector = {1, 2, 3, 4, 5};

       reverse(myVector.begin(), myVector.end());  // 反转容器



       // 现在 myVector 为 {5, 4, 3, 2, 1}

      

       return 0;

   }

        #include <algorithm> 提供了许多其他有用的算法,可以根据需要选择使用。这个头文件是C++标准库的一部分。


#include<string>

        #include <string> 是C++中用于包含 string 头文件的预处理指令。这个头文件定义了 C++ 标准库中的字符串类 std::string,它提供了一种更现代、更安全、更方便的处理字符串的方式。

        以下是一些使用 std::string 的示例:

1. 字符串声明和初始化:

  #include <string>

   using namespace std;



   int main() {

       string myString = "Hello, World!";

       // 或者

       // string myString("Hello, World!");



       return 0;

   }

2. 字符串拼接:

  #include <string>

   using namespace std;



   int main() {

       string str1 = "Hello, ";

       string str2 = "World!";

       string result = str1 + str2;  // result 包含 "Hello, World!"



       return 0;

   }

 

3. 字符串长度:

#include <string>

   using namespace std;



   int main() {

       string myString = "Hello, World!";

       int length = myString.length();  // 返回13



       return 0;

   }

4. 字符串查找:

 #include <string>

   using namespace std;



   int main() {

       string myString = "Hello, World!";

       size_t found = myString.find("World");  // 返回位置的索引,如果找不到返回 string::npos



       return 0;

   }

  

5. 字符串子串:

 #include <string>

   using namespace std;



   int main() {

       string myString = "Hello, World!";

       string subString = myString.substr(7, 5);  // 返回 "World"



       return 0;

   }

 

        使用 std::string 类型通常比使用C风格字符串更安全,并提供了更多的功能。它会自动处理字符串的内存管理,而无需手动管理内存。在C++中,推荐使用 std::string 来代替C风格的字符串。


#include<vector>  

        #include <vector> 是C++中用于包含 vector 头文件的预处理指令。这个头文件定义了C++标准库中的向量(vector)容器,它是一个动态数组,提供了许多便利的操作和功能。

        以下是一些使用 std::vector 的示例:

1. 声明和初始化:

   #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector;  // 声明一个整数向量

       // 或者

       // vector<int> myVector = {1, 2, 3, 4, 5};  // 初始化时赋值



       return 0;

   }

2. 添加元素:

   #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector;

       myVector.push_back(42);  // 在向量末尾添加元素



       return 0;

   }

  

3. 访问元素:

  #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector = {1, 2, 3, 4, 5};

       int element = myVector[2];  // 访问第三个元素,结果为3



       return 0;

   }

  

4. 遍历元素:

   #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector = {1, 2, 3, 4, 5};

       for (int i : myVector) {

           // 对每个元素执行操作

       }



       return 0;

   }

5. 获取向量大小:

 #include <vector>

   using namespace std;



   int main() {

       vector<int> myVector = {1, 2, 3, 4, 5};

       int size = myVector.size();  // 返回向量中的元素个数,结果为5



       return 0;

   }

  

        std::vector 是一个非常灵活和方便的容器,适用于需要动态大小数组的情况。它还提供了许多其他的成员函数,如插入、删除、清空等,使得在处理元素集合时更加方便。在C++中,std::vector 是一个常用的数据结构。


#include<map>

        #include <map> 是C++中用于包含 map 头文件的预处理指令。这个头文件定义了C++标准库中的 std::map 类型,它是一种关联容器,提供了键-值对的存储和检索。

        以下是一些使用 std::map 的示例:

1. 声明和初始化:

   #include <map>

   using namespace std;



   int main() {

       map<string, int> myMap;  // 声明一个字符串到整数的映射

       // 或者

       // map<string, int> myMap = {{"one", 1}, {"two", 2}, {"three", 3}};  // 初始化时赋值



       return 0;

   }

  

2. 插入键值对:

   #include <map>

   using namespace std;



   int main() {

       map<string, int> myMap;

       myMap["one"] = 1;  // 插入键值对

       myMap["two"] = 2;

       myMap["three"] = 3;



       return 0;

   }

  

3. 访问元素:

   #include <map>

   using namespace std;



   int main() {

       map<string, int> myMap = {{"one", 1}, {"two", 2}, {"three", 3}};

       int value = myMap["two"];  // 访问键为"two"的值,结果为2



       return 0;

   }

4. 遍历元素:

   #include <map>

   using namespace std;



   int main() {

       map<string, int> myMap = {{"one", 1}, {"two", 2}, {"three", 3}};

       for (const auto& pair : myMap) {

           // 对每个键值对执行操作

       }



       return 0;

   }

  

5. 查找键是否存在:

 #include <map>

   using namespace std;



   int main() {

       map<string, int> myMap = {{"one", 1}, {"two", 2}, {"three", 3}};

       if (myMap.find("two") != myMap.end()) {

           // 键"two"存在

       }



       return 0;

   }

        std::map 提供了一种高效的键-值对存储方式,其中的键是唯一的,因此可以用于创建字典或进行快速查找。它是C++中常用的关联容器之一。


#include<queue>

        #include <queue> 是C++中用于包含 queue 头文件的预处理指令。这个头文件定义了C++标准库中的 std::queue 类型,它是一个队列容器,遵循先进先出(FIFO)的原则。

        以下是一些使用 std::queue 的示例:

1. 声明和初始化:

   #include <queue>

   using namespace std;



   int main() {

       queue<int> myQueue;  // 声明一个整数队列

       // 或者

       // queue<int> myQueue({1, 2, 3});  // 初始化时赋值



       return 0;

   }

  

2. 入队和出队:

   #include <queue>

   using namespace std;



   int main() {

       queue<int> myQueue;

       myQueue.push(1);  // 将元素1入队

       myQueue.push(2);  // 将元素2入队



       int frontElement = myQueue.front();  // 获取队头元素,结果为1

       myQueue.pop();  // 出队



       return 0;

   }

  

3. 判断队列是否为空:

   #include <queue>

   using namespace std;



   int main() {

       queue<int> myQueue;

       if (myQueue.empty()) {

           // 队列为空

       }



       return 0;

   }

4. 获取队列大小:

  #include <queue>

   using namespace std;



   int main() {

       queue<int> myQueue = {1, 2, 3};

       int size = myQueue.size();  // 返回队列中的元素个数,结果为3



       return 0;

   }

5. 清空队列:

   #include <queue>

   using namespace std;



   int main() {

       queue<int> myQueue = {1, 2, 3};

       myQueue.empty();  // 清空队列



       return 0;

   }

        std::queue 提供了队列的基本操作,对于需要按照先进先出的规则进行数据处理的场景非常有用。它是C++中的标准库容器之一。


#include<cmath>

        #include <cmath> 是C++中用于包含cmath头文件的预处理指令。这个头文件提供了一系列用于数学计算的函数(cmath表示C math)。以下是一些常用的cmath函数:

1. sqrt(x): 返回x的平方根。

   double result = sqrt(25.0);  // 结果为5.0

  

2. pow(x, y): 返回x的y次方。

double result = pow(2.0, 3.0);  // 结果为8.0

  

3. abs(x): 返回x的绝对值。

 int result = abs(-10);  // 结果为10

  

4. sin(x), cos(x), tan(x): 分别返回x的正弦、余弦和正切值,x的单位是弧度。 

   double angle = 3.14159 / 2.0;  // 90度转弧度

   double sinValue = sin(angle);  // 结果为1.0

5. log(x): 返回x的自然对数。

  double result = log(2.71828);  // 结果为1.0

  

6. log10(x): 返回x的以10为底的对数。

   double result = log10(100.0);  // 结果为2.0

7. ceil(x): 返回不小于x的最小整数。

   double result = ceil(4.3);  // 结果为5.0

  

8. floor(x): 返回不大于x的最大整数。

   double result = floor(4.9);  // 结果为4.0

        这些函数在数学和科学计算中经常使用,而#include <cmath> 是为了让你能够在程序中使用这些函数而引入的头文件。


using namespace std;

        using namespace std; 是一个C++中的语句,用于引入标准命名空间(std 命名空间)。在C++中,标准库中的大多数类、函数和对象都被定义在 std 命名空间中。

        引入 std 命名空间后,你可以直接使用标准库中的类、函数和对象,而不需要在每个使用它们的地方都写上 std:: 前缀。这样可以减少代码的冗长,提高可读性。

示例:

#include <iostream>

using namespace std;



int main() {

    // 在这里可以直接使用标准库中的类和函数,而不需要写 std::

    cout << "Hello, World!" << endl;



    return 0;

}

        在上面的例子中,using namespace std; 允许我们在 main 函数中直接使用 cout 和 endl,而不必写成 std::cout 和 std::endl。

        需要注意的是,有时在大型项目或者需要避免命名冲突的情况下,可能会选择不使用 using namespace std;,而是在需要的地方显式使用 std:: 前缀。这有助于避免命名冲突和提高代码的可维护性。


总结

1. <iostream>

  • 功能: 提供输入输出流的基本功能。
  • 常用对象: cin(输入)和 cout(输出)。

2. <algorithm>

  • 功能: 提供多种算法,如排序、查找等。
  • 常用算法: sort, find, max, min, reverse

3. <string>

  • 功能: 定义了 std::string 类,用于字符串处理。
  • 常用操作: 字符串拼接、长度、查找等。

4. <vector>

  • 功能: 提供动态数组(向量)的实现。
  • 常用操作: 添加元素、访问、遍历、获取大小等。

5. <map>

  • 功能: 定义 std::map,用于键值对存储。
  • 常用操作: 插入、访问、遍历等。

6. <queue>

  • 功能: 提供队列(FIFO)的实现。
  • 常用操作: 入队、出队、获取队头元素等。

7. <cmath>

  • 功能: 提供数学计算函数,如平方根、幂运算等。
  • 常用函数: sqrt, pow, abs, sin, log 等。

8. using namespace std;

  • 功能: 引入标准命名空间,简化代码书写。
  • 注意事项: 在大型项目中可能会避免使用,以避免命名冲突。

标签:std,main,头文件,int,namespace,C++,蓝桥,using,include
From: https://blog.csdn.net/DDDDWJDDDD/article/details/142618441

相关文章

  • Day4 C++(运算符重载,模板与容器)(友元函数,运算符重载,赋值运算符,string字符串类,模板)
    1.友元friend1.1概念(掌握)定义:类实现了数据的隐藏与封装,类的数据成员一般定义为私有成员,仅能通过类的成员函数才能读写。如果数据成员定义为公共的,则又破坏了封装性。但是某些情况下,需要频繁读写类的成员,特别是在对某些成员函数多次调用时,由于参数传递、类型检查和安全......
  • 【C++】内存管理:内存分布、new/delete
        本篇主要介绍一下C++的内存管理相关知识。C++的内存管理和C语言保持一致。 1.C/C++内存分布一个程序的数据存储是需要分区的。常见的内存区域划分如下。我们学C++主要了解栈,堆,数据段,代码段。我们先看下面代码和相关问题。intglobalvar=1;staticintst......
  • C++ Practical-2 day2 运算符重载之时钟类++运算符
    系列文章目录点击直达——文章总目录文章目录系列文章目录C++Practical-2day2运算符重载之时钟类++运算符Overview1.时间类重载后缀`++`运算符来递增时间1.1.解释1.2.注意事项2.如何确保时间递增操作在多线程环境中是线程安全的?关于作者C++Practical-2day......
  • 蓝桥杯—STM32G431RBT6(TIM定时器输入捕获频率和占空比)
    一、什么是输入捕获?对比输出捕获区别?输入捕获是指对输入信号的特定事件进行检测和记录它主要用于测量输入信号的时间间隔、频率等参数。而输出捕获则是对输出信号的特定事件进行控制和监测。两者的主要区别在于作用对象不同,输入捕获关注的是输入信号,而输出捕获关注的是输出信......
  • 蓝桥杯--STM32G431RBT6(TIM定时器的输出频率和占空比,含详细原理介绍和使用方法)
    目录一、前言二、代码实现功能:​编辑按如图配置定义变量编写执行代码 显示在LCD上加入按键效果三、效果展示四、代码开源 一、前言ARR即自动重装载值(AutoReloadRegister)。相当于一个水杯,水杯容量,水满为一个周期,倒掉重新滴水。它是一个用于指定特定数值的参......
  • 10.C++程序中的循环语句
    C++中提供了三种循环语句(for循环,while循环以及do-while循环)来使程序员可以更方便地对数据进行迭代操作。if语句for语句的格式为:for(初始化语句;循环条件;迭代语句){代码块}for循环首先会执行初始化语句,主要是用于初始化循环变量和其它变量,然后判断条件是否为真,如果为真,则执......
  • 【C++】set与map
    一、什么是set、mapset和map是专门用来搜索的数据结构,是一种适合查找的容器,set和map的底层是二叉搜索树。*setset的声明:set<T>set中的相同元素只能存在一个。multiset(与set用法相同)可以存放多个相同元素。*mapmap的声明:map<T1,T2>map存储的匀速是pairmap中的与T1......
  • 【C++篇】迈入新世界的大门——初识C++(下篇)
    文章目录   前言   引用        引用的概念和定义        引用的特性        引用的使用        const引用        指针和引用的关系  inline         ......
  • 《 C++ 修炼全景指南:十三 》为什么你的代码不够快?全面掌控 unordered_set 和 unordere
    摘要本文深入探讨了C++标准库中的两大无序容器——unordered_set和unordered_map,从底层实现、核心操作、性能优化、实际应用等多个方面进行了全面分析。首先,文章介绍了这两种容器的基本概念,说明了它们基于哈希表实现的特点,尤其是在查找、插入和删除操作上具备常数时间......
  • C++设计模式
    C++设计模式提供了一些常见的问题和解决方案,帮助我们写出更清晰、更高效、更容易维护的代码。1.单例模式:就像整形诊所里有一个特别的规定,全世界只能有一个人拥有某款独一无二的鼻子,其他人都不能复制。(确保一个类只有一个实例,并提供一个全局访问点。)classSingleton{priva......