STL:使用string、vector、complex和limits
(有少量修改!)使用到了STL的算法库:
#include<algorithm>
#include<vector> //属于STL库 模板库
写库的人为了和标准C和C++库区分开
所有的模板库的文件都没有后缀
一般如 #include <iostream.h>
模板库中 #include <iostream>
Tips:在GCC下,除了要用#include <vector>外,还要加一句 unsing namespace std;才能直接使用vector<int>,否则的话,用 std::vector<int>
xxx;也可以。
要引入名字空间
方法有三个:
1, using namespace std;
2, using std::vector;
前两个方法放在cpp文件头 ,h的头也可以!
3,楼上那样,在每个地方用: std::vector<int> xx;
C++标准库大量使用了模板。尽管使用模板进行编码并不是必要的,但是使用模板代码却是非常重要的(可以节省大量代码)。本节讨论由C++标准库和STL提供的一些有用的模板类型。充分利用STL非常重要,这也是第7章讨论的主题。
1.1.1 string和basic_string<>
string库是一个涵盖非常广泛的库,它使用模板创建了一系列字符串类型。使用字符串时,在string库和cstring库中,应该优先考虑string库,原因是cstring是旧的C标准库提供的char*字符串。
将string作为一个类型使用非常简单,它实际上是一个专门包含类型char的基本容器类型。事实上,string是使用char类型实例化的模板basic_string <char T>,basic_ string<> 模板也可以用于存储宽字符类型wchar_t,这在ASCII字符集不能完全表示所需的字符集时很有用,例如汉语、日语、芬兰语或者韩国语这些语言。 basic_string<>类表示一个字符序列,它包含了顺序容器的所有常用操作,以及标准的字符串操作,例如拼接。
因为类型string和wstring是分别使用basic_string<char>和basic_string<wchar_t>进行的typedef,所以不需要直接使用模板basic_string<>。
下面的例子说明了string类型的一些特点。
文件 templateString.cpp
// String class to rewrite a sentence.
#include <iostream>
#include <string>
using namespace std;
int main()
{
string sentence, words[10];
int pos = 0, old_pos = 0, nwords, i = 0;
sentence = "Eskimos have 23 ways to ";
sentence += "describe snow";
while (pos < sentence.size()) {
pos = sentence.find(' ', old_pos);
words[i].assign(sentence, old_pos,
pos - old_pos);
cout << words[i++] << endl; // print words
old_pos = pos + 1;
}
nwords = i;
sentence = "C++ programmers ";
for (i = 1; i < nwords -1; ++i)
sentence += words[i] + ' ';
sentence += "windows";
cout << sentence << endl;
}
string类型用于从一个句子中捕获一个个单词,最初这个句子中的每个单词都由空格符分隔。空格符的位置通过成员函数find()计算得出,然后成员函数assign()从sentence中选择一个子串。最后,使用重载函数operator=()、 operator+=()和operator+()进行赋值和拼接,创建出一个新的句子。
注意,检查本地系统的文档非常重要,不同的厂商都提供了自己的实现规范。
1.1.2 标准模板库中的vector<>
我们开发了一个通用的类似数组的容器vector<>。完整的 std::vector<>由标准模板库vector提供。在多数情况下,最好使用vector类型代替基本数组类型,原因是:vector 检查数组是否越界,所以比基本数组更安全;vector能够重新分配数组长度并且有许多相关的标准方法,所以比基本数组更灵活;vector的表示与普通数组一样,所以很容易就可以取代基本数组。下面是一个示例:
#include <vector>
using namespace std;
template<class T>
T* find(vector<T> data, T v)
{
int i;
for (i = 0; i < data.size(); i++)
if (data[i] == v);
return &data[i];
return 0; // indicates failure to find v
}
注意,上述代码看上去就像是使用了典型的数组,唯一例外的是size()方法返回了vector的长度。
1.1.3 使用complex<>
complex库中的模板complex<>提供了一个复数类型,它与其他数值类型兼容。在早期的C++库中,complex并不是一个模板,它只是基于下列数据描述的一种类型:
class complex{
// ……methods
private:
double x, y;
};
现在complex则由以下模板描述:
template <class SCALAR>
class complex{
// ……methods
private:
SCALAR x, y;
};
这使用户能够根据需要决定基本类型的精度。一般来说,这些基本类型是float、double或者long double。下面是用于测试这个类型的简单代码。
文件 complex.cpp
#include <iostream>
#include <complex>
using namespace std;
int main()
{
complex<double> x(1,2.1), y;
cout << "x = " << x << endl;
y = x + 1.0;
cout << "\ny = " << y << endl;
// if (x < y) not allowed - no standard definition
// cout << "x less than y" << endl;
}
complex类型对科学家和工程师来说很重要,它说明了将C++扩展到新的领域是多么容易的事情。例如,许多科学家使用FORTRAN90编程,原因就是FORTRAN90中有复数类型。因此,C++实际上已经能够取代需要复数类型的FORTRAN程序。
注意注释掉的行是如何使用小于运算符的。在标准库中没有为complex类型定义该运算符,所以在对该模板实例化时编译将失败。如果读者自己定义了这个运算符,可以重载该运算符,运行上述代码。
1.1.4 limits和其他有用的模板
limits库描述了本地系统上的各种基础类型的特性,它通过模板类 numberic_limits<>为所有的数值类型提供了相应的属性信息。在传统的C语言方法中,每一种数据类型的属性都由唯一的宏标识符表示,例如INT_MAX表示本地系统的最大int型值。而在模板类numeric_limits<>中则定义了一个静态函数max()用于返回相应的属性值,例如numeric_ limits<int>::max()返回本地系统的最大int型值。使用模板类可以大大减少用于描述本地系统的符号名的数量。
下面是一个使用numeric_limits<>函数的例子:
文件 limits.cpp
#include <iostream>
#include <limits>
using namespace std;
int main()
{
cout << numeric_limits<char>::digits << " char\n ";
cout << numeric_limits<unsigned char>::digits << " u char\n";
cout << numeric_limits<wchar_t>::digits << " wchar_t\n";
cout << numeric_limits<int>::max() << " max int\n";
cout << numeric_limits<double>::max() << " max double " << endl;
}
digits域给出当前类型的位数。
STL:使用string、vector、complex和limits的更多相关文章
- DLL中传递STL参数,vector对象作为dll参数传递等问题(转)
STL跨平台调用会出现很多异常,你可以试试. STL使用模板生成,当我们使用模板的时候,每一个EXE,和DLL都在编译器产生了自己的代码,导致模板所使用的静态成员不同步,所以出现数据传递的各种问题,下 ...
- 转:用STL中的vector动态开辟二维数组
用STL中的vector动态开辟二维数组 源代码:#include <iostream>#include <vector>using namespace std;int mai ...
- STL中的Vector相关用法
STL中的Vector相关用法 标准库vector类型使用需要的头文件:#include <vector>. vector 是一个类模板,不是一种数据类型,vector<int> ...
- (转)C++ STL中的vector的内存分配与释放
C++ STL中的vector的内存分配与释放http://www.cnblogs.com/biyeymyhjob/archive/2012/09/12/2674004.html 1.vector的内 ...
- C++STL中的vector的简单实用
[原创] 使用C++STL中的vector, #include <stdio.h> #include<stdlib.h> #include<vector> usin ...
- STL中的vector实现邻接表
/* STL中的vector实现邻接表 2014-4-2 08:28:45 */ #include <iostream> #include <vector> #include ...
- C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法
每次忘记都去查,真难啊 /* C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法 */ /* vector常用用法 */ //头文件 #i ...
- PAT 1039 Course List for Student (25分) 使用map<string, vector<int>>
题目 Zhejiang University has 40000 students and provides 2500 courses. Now given the student name list ...
- POJ 3096 Surprising Strings(STL map string set vector)
题目:http://poj.org/problem?id=3096 题意:给定一个字符串S,从中找出所有有两个字符组成的子串,每当组成子串的字符之间隔着n字符时,如果没有相同的子串出现,则输出 &qu ...
随机推荐
- 13、Next Item Recommendation with Self-Attention---自注意力+CML
一.摘要: 自注意力机制------从用户历史交互中推断出项目-项目关系.学习每个项目的相对权重[用来学习用户的暂时兴趣表示] 二. 模型: 一部分是用于建模用户短期意图的自注意力机制,一部分是建模用 ...
- GDI 边框绘制函数(8)
绘制矩形 调用 Rectangle 函数可以绘制一个矩形(它将填充这个矩形): BOOL Rectangle( HDC hdc, // 设备环境句柄 int nLeftRect, // 左边线的位置 ...
- Ubuntu安装RTX2080显卡驱动
安装RTX2080显卡驱动 近日新购了一台DELL服务器,用于TensorFlow,由于显卡是另加的,需要安装显卡驱动. 服务器配置 服务器型号:DELL PowerEdge R730 CPU:2*I ...
- flex记忆
._rebate { display: -webkit-box; display: -moz-box; display: -webkit-flex; display: -moz-flex; displ ...
- GitLab权限介绍
访问权限 - Visibility Level 这个是在建立项目时就需要选定的,主要用于决定哪些人可以访问此项目,包含3种 Private - 私有,只有属于该项目成员才有原先查看 Internal ...
- Spring Cloud-个人理解的微服务演变过程(一)
最初架构 说明:最初我们架构是垂直的 所有功能都在一个项目里面 随着业务和用户的增长 原来一台服务器已经不能支撑现有的请求数 这个时候我们就需要部署多台服务器 集群模式 说明:我们使用nginx做代理 ...
- Spring MVC-Hello World示例(转载实践)
以下内容翻译自:https://www.tutorialspoint.com/springmvc/springmvc_hello_world_example.htm 说明:示例基于Spring MVC ...
- 程序错误通常有2种,一种是运行时错误,这种错误ide会抛出异常,我们可以根据异常寻找问题.
1.程序错误通常有2种,一种是运行时错误,这种错误ide会抛出异常,我们可以根据异常寻找问题. 2.可以根据异常寻找问题. 3.可以根据异常寻找问题
- HDU 5184
卡特兰数的一个变形而已. 一个经典的习题变过来的: n+m个人排队买票,并且满足,票价为50元,其中n个人各手持一张50元钞票,m个人各手持一张100元钞票,除此之外大家身上没有任何其他的钱币,并且初 ...
- Servlet 实现訪问量的统计小案例
今天学习了Servlet的基础知识,学习了一个统计訪问量的小案例,记录一下 package cn.selevet_01; import java.io.IOException; import java ...