导读

相信大家应该都有抢火车票的经验,每年年底,这都是一场盛宴。然而你有没有想过抢火车票这个算法是怎么实现的呢? 应该没有吧,咱们今天就来一一探讨。其实并没有你想的那么难

bitmap与位运算

redis的bitmap基本使用咱们之前已经介绍过了,如果不是很熟悉的朋友可以看看这里
redis bitmap的基本操作和应用

今天在这里咱们主要是先回顾一下位运算

12306抢票算法详解


我们以北京到西安这趟高铁为例,比如我的路线就是从北京到西安,车上如果只剩最后一张票了,那么如果有其他人,在北京到西安这条路线之间买任何一站,那么我都是买不了票的,换句话说,对于单个座位来说,必须是起点到目的地之间的所有站,都没有人买的话,那么才能被算是有票状态。

所以我们可以尝试用bitmap结合上位操作来实现这种场景,以上述北京到西安为例,我们把问题简化

  • 比如一个火车上只有4个座位
  • 北京到西安,一共是4站,其实是三个区间的,分别为北京->石家庄,石家庄->郑州,郑州->西安

首先我们给每个区间构建一个空位图(0为有票,1为无票)

接下来,比如有人买了一张从北京到西安的票

买票这个动作,比如被分配到的座位是编号为1的座位,那么我们直接把北京到西安的所有站,1号座位全部设置为1,如下图

接下来又有人买了一张从石家庄到西安的票

比如这次分配的是座位2,那么我们把石家庄到西安的所有票全部设置为1就行了,如下图

如何知道还剩几张票?

其实解决这个问题很简单,我们直接把上述位图做一个或操作就可以了

或操作结果有几个0,则说明还剩几张票。

总结

其实解决这个问题主要在于位图的构建,因为火车票对于某一个座位来说,只要起点到终点中间某一个区间被占用了(置为1),那么整个座位都是无效的这个特点,很容易想到用或操作的结果来判断买票结果,我们这里只用了4位是为了方便说明问题,实际中应该是火车上有多少座位,位图的长度就应该是多少。
好了,关于抢票算法我们就介绍到这里,你有没有Get到呢?或者你有没有更好的实现方法呢?

最新文章

  1. android Base64 加密
  2. oracle的增删改查语句
  3. Nested transactions in stored procedure of SQLServer
  4. SO从 \u 这样的字符串 构建对象
  5. c程序代码优化的一些方法
  6. eclipse进行开发
  7. 通过SecureCRT下载远程Linux服务器上的文件到本地Windows
  8. BZOJ 3401: [Usaco2009 Mar]Look Up 仰望( 单调栈 )
  9. Genymotion 插件在 Eclipse 和 Android Studio 中点击后无法初始化 Initialize Engine: failed 解决方法
  10. poj1483 It's not a Bug, It's a Feature!
  11. MySQL千万级数据JDBC插入
  12. 让Chrome看不了WWDC直播的HLS技术详解
  13. Java异常体系简析
  14. [学习笔记]java基础Java8SE开发环境搭建、第一个Java Hello World、Java程序的编译与执行
  15. [C++]Linux之虚拟文件系统[/proc]中关于CPU/内存/网络/内核等的一些概要性说明
  16. Kindeditor视频上传问题处理
  17. ie请求缓存问题,页面内容没有及时更新
  18. java注解的概念理解
  19. jQuery筛选--find(expr|obj|ele)和siblings([expr])
  20. Django之crm

热门文章

  1. SpringBoot整合SpringBatch
  2. Docker运行中文版GitLab
  3. com 组件的本知识
  4. C# 中await前后执行线程的问题
  5. Commons-Collections(二)之map
  6. 客户机与服务器TCP连接状态
  7. 深入Pulsar Consumer的使用方式&源码分析
  8. vivo全球商城时光机 - 大型促销活动保障利器
  9. DFS常规解题套路
  10. 笔记本+ubuntu18.04 关闭触摸板touchpad