C++ Primer(第五版) 第九章练习答案

C++ Primer(第五版) 第九章练习答案

9.1


/**
 * list  链表插入速度很快
 * deque 队列 头尾操作速度很快
 * vector 可变大小数组
 */

9.2

#include <deque>
#include <list>

using namespace std;

int main()
{
   
    list<deque<int>> list;

    return 0;
}

9.3


/**
 * 指向同一容器, 或尾后元素
 * end 不在 begin 之前
 */

9.4

#include <iostream>
#include <vector>

using namespace std;

bool find_int(const vector<int>::iterator &begin, const vector<int>::iterator &end, const int i)
{
   
    auto beg = begin;
    while (beg != end)
        if (*beg++ == i)
            return true;
    return false;
}

9.5

#include <iostream>
#include <vector>

using namespace std;

vector<int>::iterator find_int(const vector<int>::iterator &begin, const vector<int>::iterator &end, const int i)
{
   
    auto beg = begin;
    while (beg != end)
    {
   
        if (*beg == i)
            return beg;
        ++beg;
    }

    return end;
}

9.6



/**
 * 链表只有 == !=
 */

9.7


/**
 * int&
 * vector<int>::reference
 */

9.8


/**
 * list<string>::const_iterator
 * list<string>::iterator
 */

9.9


/**
 * 写
 * 读
 */

9.10


/**
 * vector<int>::iterator
 * vector<int>::const_iterator
 * vector<int>::const_iterator
 * vector<int>::const_iterator
 */

9.11

#include <vector>
#include <iostream>

using namespace std;

int main()
{
   
    // 空
    vector<int> vec1;
    // 1 2 3
    vector<int> vec2{
   1, 2, 3};
    // 1 2 3
    vector<int> vec3(vec2);
    // 1 2 3
    vector<int> vec4(vec3.begin(), vec3.end());
    // 0 0 0 0 0 0 0 0 0 0
    vector<int> vec5(10);
    // 1 1 1 1 1 1 1 1 1 1 
    vector<int> vec6(10, 1);

    return 0;
}

9.12


/**
 * 容器类型和元素类型必须匹配
 * 容器类型和元素类型可以不同, 元素类型可以转换到目标类型
 */

9.13

#include <iostream>
#include <list>
#include <vector>

using namespace std;

int main()
{
   
    list<int> list{
   1, 2, 3, 4, 5};
    vector<int> ivec{
   6, 7, 8, 9};

    vector<double> dvec(list.begin(), list.end());

    for(auto &i : dvec)
        cout << i << ends;
    cout << endl;

    dvec.assign(ivec.begin(), ivec.end());

    for(auto &i : dvec)
        cout << i << ends;
    cout << endl;

    return 0;
}

9.14

#include <iostream>
#include <string>
#include <list>
#include <vector>

using namespace std;

int main()
{
   
    list<const char*> list{
   "x", "i", "a", "o"};

    vector<string> vec(list.begin(), list.end());

    for (auto &i : vec)
        cout << i << ends;
    cout << endl;

    return 0;
}

9.15

#include <vector>
#include <iostream>

using namespace std;

int main()
{
   
    vector<int> v1{
   1, 2, 3, 4};
    vector<int> v2{
   1, 2, 3, 4, 5};
    vector<int> v3{
   1, 2, 3, 4};
    vector<int> v4{
   1, 1, 6, 4, 1};
    vector<int> v5{
   1, 3};

    cout << boolalpha
         << (v1 > v4) << ends
         << (v2 > v3) << ends
         << (v3 > v4) << ends
         << (v4 > vector<int>{
   1, 0, 8, 45, 4}) << ends
         << (v5 > v1) << endl;
    

    return 0;
}

9.16

#include <vector>
#include <list>
#include <string>
#include <iostream>

using namespace std;

bool compare(list<int> &list, vector<int> &vec);

int main()
{
   
    list<int> list{
   1, 2, 3, 4, 5};
    vector<int> vec{
   1, 2, 3, 4, 5};

    cout << boolalpha 
         << compare(list, vec) << endl;

    return 0;
}

bool compare(list<int> &list, vector<int> &vec)
{
   
    if (list.size() != vec.size())
        return false;

    auto lbeg = list.begin();
    auto vbeg = vec.begin();
    // 长度相同
    if (list.size() == vec.size())
        while (lbeg != list.end())
            if (*lbeg++ != *vbeg++)
                return false;
    return true;
}

9.17


/**
 * 容器和元素类型要相同
 */

9.18

#include <vector>
#include <string>
#include <list>
#include <forward_list>
#include <deque>
#include <array>
#include <iostream>

using namespace std;

int main()
{
   
    string str;
    deque<decltype(str)> deq;

    while (cin >> str)
        deq.emplace_back(str);
    
    for (auto beg = deq.begin(); beg != deq.end(); beg++)
        cout << *beg << endl;

    return 0;
}

9.19

#include <vector>
#include <string>
#include <list>
#include <forward_list>
#include <deque>
#include <array>
#include <iostream>

using namespace std;

int main()
{
   
    string str;
    list<decltype(str)> deq;

    while (ci
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值