🎈 作者:Linux猿
🎈 简介:CSDN博客专家🏆,华为云享专家🏆,Linux、C/C++、云计算、物联网、面试、刷题、算法尽管咨询我,关注我,有问题私聊!
🎈 关注专栏:C/C++面试通关【精讲】 优质好文持续更新中……🚀🚀🚀
🎈 欢迎小伙伴们点赞👍、收藏⭐、留言💬
目录
本篇文章是对 「C++ Primer 第五版」 第 2.1.2 节课后习题 2.3 ~ 2.4 的讲解。
一、练习 2.3
1.1 题目描述
读程序写结果。
#include <iostream>
#include <vector>
#include <memory>
int main()
{
unsigned u = 10, u2 = 42;
std::cout << u2 - u << std::endl; // 32
std::cout << u - u2 << std::endl; // (10 - 42 + size)%size
int i = 10, i2 = 42;
std::cout << i2 - i << std::endl; // 32
std::cout << i - i2 << std::endl; // -32
std::cout << i - u << std::endl; // 0
std::cout << u - i << std::endl; // 0
std::cout << u - i2 << std::endl; // (10 - 42 + size)%size
return 0;
}
1.2 题目解析
在上述代码中,主要是理解 unsigned 的规则,unsigned 类型的变量总是大于等于 0,如果出现小于 0,则将其转化为非负整数,即:(x + size)% size,其中 size 表示的是 unsigned 类型表示的最大值。
另一方面,int 类型和 unsigned 类型运算会转化为 unsigned 类型。
输出结果:
32
4294967264
32
-32
0
0
4294967264
二、练习 2.4
2.1 题目描述
编写程序检查你的估计是否正确,如果不正确,请仔细研读本节直到弄明白问题所在。
2.2 题目解析
见 「练习 2.3」
🎈 感觉有帮助记得「一键三连」支持下哦!有问题可在评论区留言💬,感谢大家的一路支持!🤞猿哥将持续输出「优质文章」回馈大家!🤞🌹🌹🌹🌹🌹🌹🤞