博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
趣题一则:交替放置的碟子
阅读量:6212 次
发布时间:2019-06-21

本文共 536 字,大约阅读时间需要 1 分钟。

有数量为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://kndja.baihongyu.com/

你可能感兴趣的文章
异常以及异常处理框架探析
查看>>
ECS Linux 服务器解除ssh登陆后被锁定或暂停输入输出的终端
查看>>
[BZOJ] 4196 [Noi2015]软件包管理器
查看>>
how to use http.Agent in node.js
查看>>
php数组分页类
查看>>
从NoSQL到NewSQL,谈交易型分布式数据库建设要点
查看>>
#HTTP协议学习# (一)request 和response 解析
查看>>
心情随笔
查看>>
ICMP:Internet控制报文协议
查看>>
Spring基础
查看>>
cvc-complex-type.2.3: Element 'beans' cannot have character [children]
查看>>
OCX开发与第三方OCX封装
查看>>
SQLite数据库中的SQL语句
查看>>
缓动框架的封装
查看>>
Min Stack
查看>>
hibernate-注解及配置
查看>>
在非PAE模式下,为啥PDE表开始于0xC0300000
查看>>
Python开发之数据类型
查看>>
zabbix3.2监控mongodb
查看>>
Code Project精彩系列(转)
查看>>