c++primer 10.1-10.10

10.1,1.02都在下下面的代码中

#include 
#include
#include

using namespace std;

int main()
{
    //10.1
    vector vec={1,2,3,4,5,6,7,8,9,0,2,3,1,2,3,45,23};
    int val=2;
    auto count1 = count(vec.begin(),vec.end(),val);
    cout< vec1={"xxxx","aaaa","xxxx"};
    string val2="xxxx";
    auto count2 = count(vec1.begin(),vec1.end(),val2);
    cout<

10.3

#include 
#include 
#include 
using namespace std;
int main()
{
    vector  vi = {1,2,3,4,5};
    int sum=accumulate(vi.cbegin(),vi.cend(),0);
    cout<

10.4
0是int类型,想要double类型的返回值要给0.0
10.5
两个c语言风格的数组的名字保存的是指向首字符的指针,所以equal两个c语言风格的字符串实际上是equal两个字符串的指针
10.6

#include 
#include 
#include 
using namespace std;
int main()
{
    std::vector  vi {1,2,3,4,5};
    std::fill_n(vi.begin(),vi.size(),0);
    for(int  c:vi){
        std::cout<

10.7
(1)copy要保证本容器有足够大空间放拷贝目标容器
所以在两个容器进行初始化之后要再 加一句

    vec.reserve(lst.size());

(2)
从语法来讲这段代码没有错误,编译器正常通过
但是从逻辑方面讲 ,因为reserve只改变容器的预分配空间不改变容器大小,所以这里遍历容器不会有输出,应该改为

 vector vec;
    vec.resize(10);
    fill_n(vec.begin(), 10, 0);

再进行输出就有结果了
10.8
插入迭代器不是标准库算法,它是包含在头文件"iterator"中的方法
10.9

#include 
#include 
#include
#include
#include 
using namespace std;

void elimDups(vector &word){
    //按字典排序word,便于查找重复单词
    sort(word.begin(),word.end());
    //unique重排输入范围,使得每个单词出现一次
    //unique返回最后一个不重复位置之后的迭代器
    auto end_unique = unique(word.begin(),word.end());
    //用erase删除后面的无用元素
    word.erase(end_unique,word.end());
}
int main()
{
    ifstream ifs("C:\\study\\c++test\\endless.txt");

    string str;
    vector vec;
    while(ifs>>str){
        vec.push_back(str);
    }
    for(auto c: vec){
        cout<

10.10
对所有的算法提供统一的参数进行操作,方便管理

你可能感兴趣的:(c++primer 10.1-10.10)