ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

12306 抢票算法被曝光了,居然这么简单

2021-11-22 10:00:40  阅读:268  来源: 互联网

标签:那么 石家庄 北京 抢票 算法 12306 西安 座位 位图


2021-11-15 10:11·大数据推荐杂谈

导读

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

位运算

先回顾一下位运算:

12306 抢票算法被曝光了,居然这么简单

12306抢票算法详解

12306 抢票算法被曝光了,居然这么简单

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

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

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

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

12306 抢票算法被曝光了,居然这么简单

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

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

12306 抢票算法被曝光了,居然这么简单

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

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

12306 抢票算法被曝光了,居然这么简单

如何知道还剩几张票?

其实解决这个问题很简单,我们直接把上述位图做一个或操作就可以了,因为或操作是必须全部都为0,才为0。

12306 抢票算法被曝光了,居然这么简单

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

总结

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

标签:那么,石家庄,北京,抢票,算法,12306,西安,座位,位图
来源: https://blog.csdn.net/u011277123/article/details/121465575

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有