首页 > 代码库 > 《C++primer》v5 第4章 表达式 读书笔记 习题答案
《C++primer》v5 第4章 表达式 读书笔记 习题答案
4.1
105
4.2
*vec.begin()=*(vec.begin())//先调用点运算符,再解引用
*vec.begin()+1=(*vec.begin())+1//先解引用,再加一
4.3略?
4.4
(12/3*4)+(5*15)+(24%4/2)=91
4.5
(a)-86(b)-16
(c)0 (d)0
4.6
n%2
4.7
溢出:计算结果超出该数据类型所能表示的范围
2147483647+1
1U-2
...
4.8
比较低。。
4.9
首先判断cp是否为空指针,若非空指针则判断cp指向的是否是空字符串
4.10
int val; while(cin>>val&&val!=42);
4.11
int main(){ int a,b,c,d; cin>>a>>b>>c>>d; if(a>b&&b>c&&c>d) cout<<"Yes"<<endl; else cout<<"No"<<endl; return 0;}
4.12
由于<优先级高于!=,所以先执行j<k返回一个bool类型,可能是0或1,再执行!=运算。最终返回一个bool运算结果,可能是0或1。
4.13
(a)d=3,i=3 因为是从右往左执行的
(b)i=3,d=3.5
4.14
第一种将报错,42是常量,不能被赋值
第二种,该表达式返回42,为真,但是可能并非设计者原意
4.15
指针数据类型与int和double都是不相容的,不能这样赋值。
正确答案:dval=ival=*pi=0;
4.16
(a)将先执行 !=,再执行=。
正解:if((p=getPtr())!=0)
(b)=是赋值,不是判断是否相等
正解:if(i==1024)
4.17
前置运算符,先求值再返回该对象用于左值运算对象
后置运算符,返回该对象的一个副本作为右值运算对象,再求值
4.18
使用前置运算符将不能输出第一个元素,而且会访问越界
另外,经测试,++*it和*++it是不一样的。前置可能导致死循环,因为只是给数值自加了。
4.19
(a)如果ptr不是空指针,那么判断ptr指向的是否是0,再将ptr指向下一个位置
(b)先判断ival是为是0,再将ival自加1,再判断ival是否为0。
(c)等价于vec[ival]<=vec[ival+1],++ival;
4.20
(a)合法。等价于*iter,iter++;
(b)非法。string类型不支持++运算。
(c)非法。先执行成员访问运算符,而iter没有empty这个成员,所以将报错。
(d)正确。等价于(*iter).empty()
(e)正确。等价于++(*iter)
(f)正确。等价于iter->empty(),iter++;
4.21
int main(){ vector<int> vec; int val; while(cin>>val) vec.push_back(val); for(auto &i:vec) if(i%2) i=i*2; for(auto i:vec) cout<<i<<endl; return 0;}
4.22
int main(){ int val; while(cin>>val) { string grade=(val>90)?"high pass":(60<=val&&val<=75)?"low pass":(val<60)?"fail":"pass"; cout<<grade<<endl; } return 0;}
明显if语句更好懂
int main(){ int val; while(cin>>val) { if(val>90) cout<<"high pass"<<endl; else if(val<60) cout<<"fail"<<endl; else { if(60<=val&&val<=75) cout<<"low pass"<<endl; else cout<<"pass"<<endl; } } return 0;}
4.23
由于加法运算优先级高于条件运算符,因此会先执行加法,得到一个string类型,而string与字符比较,会报错。
正解: string p=s+(s[s.size()-1]==‘s‘?"":"s");
4.24?
不是很懂结合律这块。留着以后研究。
4.25
不懂Latin-1字符集是什么。。
该表达式,第一步取反得到10001110
第二步左移6位得到10000000
4.26
unsigned int在不同机器上位数不同,不能确保一定可以表示30个学生
4.27
ul1=011
ul2=111
(a)011=3
(b)111=7
(c)1
(d)1
4.28
cout<<"short:"<<sizeof(short)<<endl; cout<<"int:"<<sizeof(int)<<endl; cout<<"long:"<<sizeof(long)<<endl; cout<<"long long:"<<sizeof(long long)<<endl; cout<<"float:"<<sizeof(float)<<endl; cout<<"double:"<<sizeof(double)<<endl; cout<<"char:"<<sizeof(char)<<endl;
这是在我的机器上的输出:
short:2int:4long:4long long:8float:4double:8char:1
4.29
int main(){ int x[10]; int *p=x; cout<<sizeof(x)<<" "<<sizeof(*x)<<" "<<sizeof(x)/sizeof(*x)<<endl; cout<<sizeof(p)<<" "<<sizeof(*p)<<" "<<sizeof(p)/sizeof(*p)<<endl; return 0;}
sizeof(x)是一个大小为10的int数组的空间
sizeof(*x)是一个指向int的指针的空间
sizeof(p)是一个指向int的指针的空间
sizeof(*p)是一个int元素的空间
40 4 104 4 1
以上是输出
4.30
(a)sizeof (a+b)
(b)sizeof (p->mem[i])
(c)sizeof (a<b) 注意小于优先级比sizeof低
(d)sizeof (f())
4.31
后置会额外返回一个对象的副本,使用前置运算符更符合编程的初衷,效率也更高
4.32
遍历ia数组。
4.33
如果someValue为真,则++x,++y并返回自加以后的y。如果为假,则--x,--y并返回自减以后的y。
注意逗号运算符从左向右依次求值,最终返回右侧表达式的值
4.34
(a)float转为bool
(b)+:int转float,=float转double
(c)*:char转int,+int转double
4.35
(a)char转int,再转char?
(b)*int转double,-unsignedint转double,=double转float
(c)*unsignedint转float,float转double
(d)int转float,float转double,double转char
为避免精度损失,整型与浮点型计算,整型会被转化成浮点型
4.36
i*=(int)d;
4.37
(a)pv=static_cast<void*>(ps);
(b)i=static_cast<int*>(pc);
(c)pv=static_cast<void*>(&d);
(d)pc=static_cast<char*>(pv);
注意强转的数据类型要用<>扩起来,变量要用()括起来。
4.38
把j/i的结果强转成double赋值给slope
int main(){ int i=3,j=5; double slope=static_cast<double>(j/i); cout<<slope<<endl; return 0;}
比如上面的结果,输出1