1 void ch8_1_print(const std::string & str, int n = 0 ) {
2 using namespace std;
3 static int flag = 0;
4 ++ flag;
5 if (!n)
6 cout << str << endl;
7 else {
8 for (int i = flag; i; -- i)
9 cout << str << endl;
10 }
11 }
12 void ch8_1() {
13 using namespace std;
14 string str{"ch8_1"};
15 ch8_1_print(str);
16 ch8_1_print(str, 100);
17 }
18
19 void ch8_2_setvalue(CandyBar & bar, const char * bd = "Millennium Munch", double w = 2.85, unsigned long k = 350) {
20 strcpy(bar.brand, bd);
21 bar.weight = w;
22 bar.kll = k;
23 }
24
25 void ch8_2_show(const CandyBar & bar) {
26 using namespace std;
27 cout << "brand: " << bar.brand << endl;
28 cout << "weight: " << bar.weight << endl;
29 cout << "energy: " << bar.kll << endl;
30 }
31
32 void ch8_2() {
33 using namespace std;
34 CandyBar bar;
35 cout << "default value: " << endl;
36 ch8_2_setvalue(bar);
37 ch8_2_show(bar);
38 char s[] = "nnn";
39 double w = 100.123;
40 unsigned long k = 1234;
41 cout << "reset value: " << endl;
42 ch8_2_setvalue(bar,s,w,k);
43 ch8_2_show(bar);
44 }
45 void ch8_3_str2upper(std::string & str) {
46 for (int i = 0; i < str.size(); ++ i)
47 str[i] = toupper(str[i]);
48 }
49 void ch8_3() {
50 using namespace std;
51 string s;
52 while (true) {
53 cout << "enter string(q to quit): ";
54 getline(cin, s);
55 if (s == "q")
56 break;
57 ch8_3_str2upper(s);
58 cout << "upper: " << s << endl;
59 }
60 }
61
62 void ch8_4_set(stringy & sy, const char * str) {
63 sy.str = new char[strlen(str)];
64 strcpy(sy.str, str);
65 sy.ct = strlen(str);
66 }
67
68 void ch8_4_show(const stringy & sy, int n = 0) {
69 using namespace std;
70 if (!n)
71 cout << sy.str << endl;
72 else {
73 for (int i = 0; i < n; ++ i)
74 cout << sy.str[i];
75 cout << endl;
76 }
77 }
78
79 void ch8_4_show(const char * str, int n = 0) {
80 using namespace std;
81 if (!n)
82 cout << str << endl;
83 else {
84 for (int i = 0; i < n; ++ i)
85 cout << str[i];
86 cout << endl;
87 }
88 }
89
90 void ch8_4() {
91 using namespace std;
92 stringy beany;
93 char testing[] = "Reality isn't what it used to be.";
94 ch8_4_set(beany, testing);
95 ch8_4_show(beany);
96 ch8_4_show(beany, 2);
97 testing[0] = 'D';
98 testing[1] = 'u';
99 ch8_4_show(testing);
100 ch8_4_show(testing, 3);
101 ch8_4_show("Done!");
102 }
103
104 template <typename T>
105 unsigned int ch8_5_max(const T * arr) {
106 unsigned int max_index = 0;
107 for (int i = 1; i < 5; ++ i)
108 if (arr[i] > arr[max_index])
109 max_index = i;
110 return max_index;
111 }
112
113 void ch8_5() {
114 using namespace std;
115 int arr_int[5]{1,3,5,2,4};
116 double arr_dou[5]{3.14,2.14,5.12,8.12,10.30};
117 cout << "max int: " << arr_int[ch8_5_max(arr_int)] << endl;
118 cout << "max dou: " << arr_dou[ch8_5_max(arr_dou)] << endl;
119 }
120
121 template <typename T>
122 T ch8_6_maxn(T * arr, unsigned int n) {
123 int max_index = 0;
124 for (int i = 1; i < n; ++ i)
125 if (arr[i] > arr[max_index])
126 max_index = i;
127 return arr[max_index];
128 }
129
130 template <> char * ch8_6_maxn<char *>(char * arr[], unsigned int n) {
131 int max_index = 0;
132 for (int i = 1; i < n; ++ i)
133 if (strlen(arr[i]) - strlen(arr[max_index]) > 0)
134 max_index = i;
135 return arr[max_index];
136 }
137
138 void ch8_6() {
139 using namespace std;
140 int arr_int[6]{1,2,3,4,5,6};
141 double arr_dou[4]{1.1,2.2,3.3,4.4};
142 char * arr_str[5]{
143 "h", "he", "hel", "hell", "hello"
144 };
145 cout << "max double: " << ch8_6_maxn(arr_int, 6) << endl;
146 cout << "max int : " << ch8_6_maxn(arr_dou, 4) << endl;
147 cout << "max str : " << ch8_6_maxn(arr_str, 5) << endl;
148 }
149
150 template <typename T>
151 T ch8_7_sumarray(T * arr, int n) {
152 T sum{0};
153 for (int i = 0; i < n; ++ i)
154 sum += arr[i];
155 return sum;
156 }
157
158 template <typename T>
159 T ch8_7_sumarray(T * arr[], int n) {
160 T sum{0};
161 for (int i = 0; i < n; ++ i)
162 sum += * arr[i];
163 return sum;
164 }
165
166 void ch8_7() {
167 using namespace std;
168 int things[6]{13,31,103,301,310,130};
169 debts mr_E[3]{
170 {"Ima Wolfe", 2400.0},
171 {"Ura Foxe", 1300.0},
172 {"Iby Stout", 1800.0}
173 };
174 double * pd[3];
175 for (int i = 0; i < 3; ++ i)
176 pd[i] = &mr_E[i].amount;
177 cout << "sum of things: " << ch8_7_sumarray(things, 6) << endl;
178 cout << "sum of debts: " << ch8_7_sumarray(pd, 3) << endl;
179 }

【C++ Primer Plus】编程练习答案——第8章的更多相关文章

  1. 【C++ Primer Plus】编程练习答案——第12章

    1 // chapter12_1_cow.h 2 3 4 #ifndef LEARN_CPP_CHAPTER12_1_COW_H 5 #define LEARN_CPP_CHAPTER12_1_COW ...

  2. 【C++ Primer Plus】编程练习答案——第11章 (待更新)

    最近开学,事情较多,过两天更新...

  3. 【C++ Primer Plus】编程练习答案——第10章

    1 // chapter10_1_account.h 2 3 #ifndef LEARN_CPP_CHAPTER10_1_ACCOUNT_H 4 #define LEARN_CPP_CHAPTER10 ...

  4. 【C++ Primer Plus】编程练习答案——第9章

    1 // chapter09_golf.h 2 3 #ifndef LEARN_CPP_CHAPTER09_GOLF_H 4 #define LEARN_CPP_CHAPTER09_GOLF_H 5 ...

  5. 【C++ Primer Plus】编程练习答案——第7章

    1 double ch7_1_harmonicaverage(double a, double b) { 2 return 2 / (1 / a + 1 / b); 3 } 4 5 void ch7_ ...

  6. 【C++ Primer Plus】编程练习答案——第6章

    1 void ch6_1() { 2 using namespace std; 3 char ch; 4 while ((ch = cin.get()) != '@') { 5 if (isdigit ...

  7. 【C++ Primer Plus】编程练习答案——第5章

    1 void ch5_1() { 2 using namespace std; 3 int small, big, sum{0}; 4 cout << "enter small ...

  8. 【C++ Primer Plus】编程练习答案——第4章

    1 void ch4_1() { 2 using namespace std; 3 string fname, lname; 4 char grade; 5 unsigned int age; 6 c ...

  9. 【C++ Primer Plus】编程练习答案——第3章

    1 void ch3_1() { 2 using namespace std; 3 unsigned int factor = 12; 4 unsigned int inch, feet; 5 cou ...

随机推荐

  1. kubebuilder实战之八:知识点小记

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  2. 新版idea无法导入mavenweb模板

    目前没有任何办法,最好是下个旧版的

  3. (一)Superset 1.3图表篇——Table

    本系列文章基于Superset 1.3.0版本.1.3.0版本目前支持分布,趋势,地理等等类型共59张图表.本次1.3版本的更新图表有了一些新的变化,而之前也一直没有做过非常细致的图表教程. 而且目前 ...

  4. Linux下查看哪个网口插了网线

    场景: 一台服务器有多个网卡,一个网卡有多个网口,当插了一根网线的时候,不知道网线是插在哪一个网口. 1.查看网口信息 2.查看网口是否插了网线(命令ethtool) 命令:ethtool + 网口名 ...

  5. fetch ios低版本兼容cannot clone a disturbed response

    报错信息 ios 11以下 cannot clone a disturbed response github.com/github/fetc- 问题发生场景 使用了一个或者多个三方库 三方库或者自己的 ...

  6. [考试总结]noip模拟44

    这个真的是一个 \(nb\) 题. 考试快要结束的时候,在机房中只能听到此起彼伏的撕吼. 啊---------- 然后人们预测这自己的得分. \(\color{red}{\huge{0}}\) \(\ ...

  7. Set代码

    现有一整数集(允许有重复元素),初始为空.我们定义如下操作:add x 把 x 加入集合del x 把集合中所有与 x 相等的元素删除ask x 对集合中元素x的情况询问 对每种操作,我们要求进行如下 ...

  8. 1004. 最大连续1的个数 III

    1004. 最大连续1的个数 III 给定一个由若干 0 和 1 组成的数组 A,我们最多可以将 K 个值从 0 变成 1 . 返回仅包含 1 的最长(连续)子数组的长度. 示例 1: 输入:A = ...

  9. PTA——c++类与对象

    对于给定的一个字符串,统计其中数字字符出现的次数. 类和函数接口定义: 设计一个类Solution,其中包含一个成员函数count_digits,其功能是统计传入的string类型参数中数字字符的个数 ...

  10. 【Python】python 2.7.16 x64 百度网盘

    倒霉官网下载太慢,下好了分享出来,也给自己留一个备份. 链接:点这里提取码:znaf PS: py2.7版本 for win 64位