趣题一则:交替放置的碟子

简介:

有数量为2n的一排碟子,n黑n白交替放置。现在要把黑碟子都放在右边,白碟子都放在左边,但只允许通过交换相邻碟子的位置来实现。实现这个过程要交换多少次?

分析

首先把问题转化一下,用1表示黑碟子,0表示白碟子,那么目前的顺序是:

1010...1010

结果要求1都放在右边,0都放在左边。这个题目看起来很眼熟。看关键字:交换相邻的碟子排好顺序。嗯,就是经常出现在面试中的冒泡排序了。

为便于观察,假设目前有6个碟子:101010。使用冒泡排序,第一次迭代,碟子序列变为:010101,交换3次。在进行第二次迭代之前,观察一下。

现在,不仅第一个碟子就位,最后一个也是了,因此第二次迭代只需要对第2到第5个进行排序,巧合的是,碟子[2->5]仍然是10交替出现,不过比上一次少了两个,这样就简单了,可以得到结论:对于2n个碟子,可以使用n次迭代完成,交换的次数分别是:n+(n-1)+...+2+1,即n(n+1)/2。

顺便说一句,对于常见的经典排序算法,要么是简单直观的,如选择排序、插入排序,其实就是平时摸牌时所用的方法;要么是效率较高的,如快速排序、归并排序。我觉得冒泡排序既不直观,也不高效,也许就因为得了一个好名字,就名扬算法界了,所以名字神马的很重要!

 

参考

《算法设计与分析基础》


本文转自一个程序员的自省博客园博客,原文链接:http://www.cnblogs.com/anderslly/archive/2012/04/16/swaping-disks.html,如需转载请自行联系原作者

目录
相关文章
|
3月前
|
算法 计算机视觉
图像去雨-雨线清除-图像处理-(计算机作业附代码)
图像去雨-雨线清除-图像处理-(计算机作业附代码)
65 1
|
3月前
|
算法 Java
算法编程(三十):交替合并字符串
算法编程(三十):交替合并字符串
67 0
|
2月前
|
存储 机器学习/深度学习 算法
python 五种算法转置后翻转、层次旋转、递归分块、一次性旋转、环状替换 实现旋转图像【力扣题48】
python 五种算法转置后翻转、层次旋转、递归分块、一次性旋转、环状替换 实现旋转图像【力扣题48】
|
2月前
leetcode题解:1768.交替合并字符串
leetcode题解:1768.交替合并字符串
24 0
一个有意思的面试题 → 线程交替输出问题
用两个线程,一个输出数字,一个输出字母,交替输出 1A2B3C4D...26Z
|
设计模式 算法 前端开发
第50/90步《前端篇》第11章 重构音频管理、碰撞检测和右挡板移动算法 第31课
今天学习《前端篇》第11章 重构音频管理、碰撞检测和右挡板移动算法 第31课 设计模式重构六:适配器模式、桥接模式和装饰模式
68 0
|
自然语言处理 算法
【数字IC手撕代码】Verilog固定优先级仲裁器|题目|原理|设计|仿真
【数字IC手撕代码】Verilog固定优先级仲裁器|题目|原理|设计|仿真
【数字IC手撕代码】Verilog固定优先级仲裁器|题目|原理|设计|仿真
【数字IC手撕代码】Verilog轮询仲裁器|题目|原理|设计|仿真
【数字IC手撕代码】Verilog轮询仲裁器|题目|原理|设计|仿真
【数字IC手撕代码】Verilog轮询仲裁器|题目|原理|设计|仿真
|
数据安全/隐私保护
【数字IC手撕代码】Verilog伪随机数生成器|线性反馈移位寄存器|题目|原理|设计|仿真
【数字IC手撕代码】Verilog伪随机数生成器|线性反馈移位寄存器|题目|原理|设计|仿真
【数字IC手撕代码】Verilog伪随机数生成器|线性反馈移位寄存器|题目|原理|设计|仿真
|
数据可视化 搜索推荐 程序员
程序人生 - “无代码”时代,离我们还有多远?
程序人生 - “无代码”时代,离我们还有多远?
190 0
程序人生 - “无代码”时代,离我们还有多远?