C++primer 9.3.1节练习

练习9.18

 1 #include <iostream>
 2 #include <vector>
 3 #include <list>
 4 #include <deque>
 5 #include <string>
 6 #include <iterator>
 7
 8 using namespace std;
 9
10 int main()
11 {
12     deque<string> de;
13     string word;
14     while (cin >> word)
15     {
16         de.push_back(word);
17     }
18     for (auto it = de.begin(); it != de.end(); ++it)
19         cout << *it << endl;
20     system("pause");
21     return 0;
22 }

练习9.19

 1 #include <iostream>
 2 #include <vector>
 3 #include <list>
 4 #include <deque>
 5 #include <string>
 6 #include <iterator>
 7
 8 using namespace std;
 9
10 int main()
11 {
12     list<string> de;
13     string word;
14     while (cin >> word)
15     {
16         de.push_back(word);
17     }
18     for (auto it = de.begin(); it != de.end(); ++it)
19         cout << *it << endl;
20     system("pause");
21     return 0;
22 }

练习9.20

 1 #include <iostream>
 2 #include <vector>
 3 #include <list>
 4 #include <deque>
 5 #include <string>
 6 #include <iterator>
 7
 8 using namespace std;
 9
10 void print(const deque<int> de);
11
12 int main()
13 {
14     list<int> num;
15     num.insert(num.begin(), { 1,2,3,4,5,6,7,8,9,10 });
16     deque<int> num1;
17     deque<int> num2;
18     for (auto it = num.begin(); it != num.end(); ++it)
19     {
20         if ((*it) % 2 == 0)
21             num1.push_back(*it);
22         else
23             num2.push_back(*it);
24     }
25     print(num1);
26     cout << endl;
27     print(num2);
28     system("pause");
29     return 0;
30 }
31
32 void print(const deque<int> de)
33 {
34     for (auto c : de)
35         cout << c << endl;
36 }

练习9.21

 1 #include <iostream>
 2 #include <vector>
 3 #include <list>
 4 #include <deque>
 5 #include <string>
 6 #include <iterator>
 7
 8 using namespace std;
 9
10
11 int main()
12 {
13     vector<string> lst;
14     string word;
15     auto iter = lst.end();
16     while (cin >> word)
17     {
18         iter = lst.insert(iter, word);
19     }
20     for (auto c : lst)
21         cout << c << endl;
22     system("pause");
23     return 0;
24 }

练习9.22

 1 #include <iostream>
 2 #include <vector>
 3 #include <list>
 4 #include <deque>
 5 #include <string>
 6 #include <iterator>
 7
 8 using namespace std;
 9
10
11 int main()
12 {
13     int some_val = 1;
14     vector<int> iv{ 1,2,3,4,5,6,7,8,9,10 };
15     auto i = iv.size();
16     vector<int>::iterator iter = iv.begin(),
17         mid = iv.begin() + iv.size() / 2;
18     while (iter != mid)
19     {
20         if (*iter == some_val)
21         {
22             iter = iv.insert(iter, 2 * some_val);
23             iter = iter + 2;
24             mid = iv.begin() + i / 2;
25         }
26         else
27             ++iter;
28     }
29     for (auto c : iv)
30         cout << c << endl;
31     system("pause");
32     return 0;
33 }

一个是该循环是个死循环,iter永远不会不等于mid,第二点很重要,自己在做题时有遗漏,向一个vector、string、deque插入元素会使所有指向容器的迭代器、引用和指针失效。

时间: 2024-10-31 15:26:29

C++primer 9.3.1节练习的相关文章

C++primer 15.7.3节练习

练习15.26 写的时候不小心写到了派生类Disc_quote,其实是一样的,主要明白原理即可 1 #include <iostream> 2 #include <string> 3 #include <utility> 4 #include <memory> 5 #include <vector> 6 7 using namespace std; 8 9 class Quote { 10 public: 11 Quote() : bookNo(

C++primer 15.2.2节练习

练习15.4 a)错误,一个类不能派生它本身 b)正确,Derived从他的基类Base派生,且规定派生类从基类继承的数据成员对于派生类的用户是不可见. c)错误,派生类的声明与其他类相差不大,声明中包含类名但是不包含他的派生列表: 练习15.5 1 #include <iostream> 2 #include <string> 3 #include <utility> 4 #include <memory> 5 #include <vector>

C++primer 14.2.1节练习

练习14.6 1 #include <iostream> 2 #include <string> 3 #include <memory> 4 #include <vector> 5 #include <algorithm> 6 #include <numeric> 7 8 using namespace std; 9 10 class Sales_data { 11 friend istream& operator >&

C++primer 15.7.4节练习

练习15.27 1 #include <iostream> 2 #include <string> 3 #include <utility> 4 #include <memory> 5 #include <vector> 6 7 using namespace std; 8 9 class Quote { 10 public: 11 Quote() : bookNo(""), price(0.0) { cout <<

C++ Primer 6.5.3节练习

练习 6.47: 改写6.3.2节(第205页)练习中使用递归输出vector内容的程序,使其有条件地输出与执行过程有关的信息.例如,每次调用时输出vector对象的大小.分别在打开和关闭调试器的情况下编译并执行这个程序. ///这一题需要在前面输出vector内容的程序中,添加新的功能---->有条件地输出与执行过程有关的信息. 为了简便解答该题,我们采用vector引用,vector的类型是string型,在过程中不改变容器大小. 经过测试得到一个现象,编译器将会按照 #define DEB

C++primer 11.3.5节练习

练习11.27 对于multimap来说统计关键字出现的次数用count会很好,而对于map来说寻找关键字来说更加妥当: 练习11.28 1 #include <iostream> 2 #include <string> 3 #include <set> 4 #include <map> 5 #include <algorithm> 6 #include <vector> 7 #include <algorithm> 8

C++primer 11.2.3节练习

练习11.12 1 #include<iostream> 2 #include<string> 3 #include <iostream> 4 #include <vector> 5 #include <algorithm> 6 #include <list> 7 #include <functional> 8 #include <iterator> 9 #include <map> 10 #inc

C++primer 7.5.3节练习

练习7.43 网上的答案 1 #include <iostream> 2 using std::cout; 3 using std::endl; 4 5 class Nodefault 6 { 7 public: 8 Nodefault(int i) 9 { 10 val = i; 11 } 12 int val; 13 }; 14 15 class C 16 { 17 public: 18 Nodefault nd; 19 C(int i = 0) : nd(i) { } 20 }; 21

C++primer 7.1.3节练习

练习7.6 1 #include <iostream> 2 #include <string> 3 #include "factmain.h" 4 using namespace std; 5 6 struct Sales_data { 7 string isbn() const { return bookNo; } 8 Sales_data &combine(const Sales_data&); 9 string bookNo; 10 uns

c++ primer 6.5.1节练习答案

练习6.40 a)正确 b)错误,一旦某个形参被赋予了默认值,他后面的所有形参都必须有默认值. 练习6.41 a)错误,ht没有默认实参,而a的实参列表里也没有给出实参: b)合法,调用init(24 ,10 ,' '): c)虽然合法,但是与程序猿的设计初衷不符,*会转换成十进制的数43,相当于调用init(14, 43, ' '): 练习6.42 1 string make_plural(size_t ctr, const string &word, const string &end