本系列博客习题来自《算法(第四版)》,算是本人的读书笔记,如果有人在读这本书的,欢迎大家多多交流。为了方便讨论,本人新建了一个微信群(算法交流),想要加入的,请添加我的微信号:zhujinhui207407 谢谢。另外,本人的个人博客 http://www.kyson.cn 也在不停的更新中,欢迎一起讨论
知识点
- 冒泡排序
题目
1.1.26 将三个数字排序。假设 a、b、c 和 t 都是同一种原始数字类型的变量。证明以下代码能够将 a、 b、c 按照升序排列:
if (a > b) { t = a; a = b; b = t; }
if (a > c) { t = a; a = c; c = t; }
if (b > c) { t = b; b = c; c = t; }
1.1.26 Sorting three numbers. Suppose that the variables a, b, c, and t are all of the same numeric primitive type. Show that the following code puts a, b, and c in ascending order:
if (a > b) { t = a; a = b; b = t; }
if (a > c) { t = a; a = c; c = t; }
if (b > c) { t = b; b = c; c = t; }
分析
这是冒泡排序的一种思路:通过不停交换数字,将小的数冒泡到最上面。
答案
if (a > b) { t = a; a = b; b = t; } // 保证a为a、b两数的较小者
if (a > c) { t = a; a = c; c = t; } // 保证a为a、b、c三数中的最小者
if (b > c) { t = b; b = c; c = t; } // 保证b为比a大的b、c两数的较小者,从而必有c为三数中的最大者
广告
我的首款个人开发的APP壁纸宝贝上线了,欢迎大家下载。