【C++Primer】第五版习题解答--第四章【学习笔记】
ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考。
作者:cosefy
Date: 2020/1/11
第四章:表达式
练习4.6:
判断奇数:if num%2!=0
练习4.9:
const char* cp = "hello world";
if (cp && *cp)
if语句判断cp表示的字符串以及* cp指向的第一个字符是否都为空。
练习4。10:
实现:为while循环写一个条件,使其从标准输入中读取整数,遇到42时停止。
#include<iostream>
using namespace std;
int main()
{
int i;
while (cin >> i&&i!=42) ;
return 0;
}
练习4.11:
a>b && b>c && c>d
练习4.12:
先判断i<k,返回bool类型,然后判断i是否不等于返回的布尔类型,由于i是整数,故在返回布尔类型和i的比较中,布尔类型会转换为0或1,进行判断,最终返回bool类型的结果。
练习4.13:
赋值运算符运算顺序是从右向左。
(a):值3.5先赋值给int型的i,则i=3,再把i的值赋值给double型d,d=3.0.
(b):值3.5先赋值给double型d,d=3.5,再把d的值赋值给int型i,i=3。
练习4.14:
if(42=i) //字面值不能作为左值,程序将会出错
if(i=42) //i被赋值42,由于i不等于0,故将会执行if块内的程序
练习4.15:
不可以将指针值赋值给int和double型数据。
dval=ival=(* pi)=0;
练习4.16:
(a):赋值运算符的优先级低于关系运算符的优先级。可以给赋值部分语句加上括号。
(b):==写成了=。
练习4.19:
a: 指针ptr不为空,并且ptr指向的值也不为0。
b: ival的值是否为0,同时ival加一后是否为0。
c: 此处求值的顺序是任意的,可能先访问vec[ival],也有可能先进行vec[ival++],得到的判定形式不同。
练习4.20:
a: 合法,先解引用,后自增地址。
b: 不合法,字符串类型无法自增
c: 不合法,iter无法调用empty()
d: 合法,判断iter指向的对象是否为空
e: 不合法,字符串无法自增
f: 合法,先判断所指对象是否为空,再自增地址。
练习4.21:
实现:使用条件运算符从vector中找出奇数并翻倍。
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int>v1{ 1,2,3,4,5,6,7,8,9 };
for (auto& i : v1)
{
i = i % 2 ? i * i : i;
cout << i << endl;
}
return 0;
}
练习4.22:
实现:输入一个分数,用条件运算符判断分数属于哪个层级。
#include<iostream>
#include<vector>
using namespace std;
int main()
{
unsigned grade;
cin >> grade;
cout << ((grade > 90) ? "high pass" : (grade > 75) ? "pass" : (grade > 60) ? "low pass" : "failed");
return 0;
}
实现:输入一个分数,用一个或多个if语句判断分数属于哪个层级。
#include<iostream>
#include<vector>
using namespace std;
int main()
{
unsigned grade;
cin >> grade;
if (grade > 90)
cout << "high pass";
else if (grade > 75)
cout << "pass";
else if (grade > 60)
cout << "low pass";
else
cout << "failed";
return 0;
}
练习2.23:
因为条件运算符的优先级很低,所以需要给条件运算符的表达式加上括号。
练习4.26:
由于int型在不同机器上位数不同,所以在这个例子中,可能会出现数据溢出的问题。
练习4.27:
a: 3
b: 7
c: 1
d: 1
练习4.29:
#include<iostream>
using namespace std;
int main()
{
int x[10];
int* p = x;
cout << sizeof(x) / sizeof(*x) << endl;
cout << sizeof(p) / sizeof(*p) << endl;
return 0;
}
运行结果:
原因:数组占据空间大小除以每个元素空间大小(40/4=10);指针所占空间大小除以指向元素所占空间大小(4/4=1)。
练习4.33:
someValue为真时,执行
++x,++y;
someValue为假时,执行
--x,--y;
练习4.34:
a: fval转换为bool类型。
b: fval和ival都转化double类型。
c: cval先转化为int型,得到的乘积再转化为double型。