- Go程序员面试算法宝典
- 猿媛之家组编 董良松 楚秦等编著
- 206字
- 2020-06-25 22:38:08
2.7 如何设计一个排序系统
难度系数:★★★★☆
被考查系数:★★★☆☆
题目描述:
请设计一个排队系统,能够让每个进入队伍的用户都能看到自己在队列中所处的位置和变化,队伍可能随时有人加入和退出;当有人退出影响到用户的位置排名时需要及时反馈到用户。
分析与解答:
本题不仅要实现队列常见的入队列与出队列的功能,而且还需要实现队列中任意一个元素都可以随时出队列,且出队列后需要更新队列用户位置的变化。实现代码如下:
![](https://epubservercos.yuewen.com/C814A1/14700476404565706/epubprivate/OEBPS/Images/88_01.jpg?sign=1738926013-ogx2zmgJjZKzaXn2oDQAj2TqxHkgmetE-0-5b2fb6a859e2e92a0dc5be45398871ee)
![](https://epubservercos.yuewen.com/C814A1/14700476404565706/epubprivate/OEBPS/Images/89_01.jpg?sign=1738926013-ZuZJGhdQvHzgxuYfwrXaAdgcUZS1nCXb-0-fae4a77efc3aa355005a893423a2b72d)
程序的运行结果为
![](https://epubservercos.yuewen.com/C814A1/14700476404565706/epubprivate/OEBPS/Images/89_02.jpg?sign=1738926013-NKIKmydb3yrOy2mvMPYWpOu37D7CQQoA-0-68babd5dc84fa5b25319d72ca8b5c758)