C语言 | 您所在的位置:网站首页 › 银行排号v优先于a吗还是b › C语言 |
这两天在网上看到这个题目,感觉挺有意思,就做了一下。我在网上看到其他人都是用C++做的,因为不懂C++语言,没看懂,尝试着用C语言做了该题。希望能来看该题的大神指点指点,估计还有些bug没找出来。 本人编程基础差,利用闲暇的时间来做此题,总时间加在一起,花了一天左右吧。网上有人花了半小时做完该题,让我膜拜啊,太佩服。 进入正题吧,题目要求如下: 实现一个简易的银行排号叫号系统 get 取号 示例:"get"或"get vip"call 叫号 示例:"call"delete 删除号码 示例:"delete 5"count 获取当前排队总人数 示例:"count"countN 获取号码N以前的排队人数 示例:"countN"reset 重置排号机 示例:"reset"quit 退出排号机 示例:"quit"运行时间限制: 无限制内存限制: 无限制输入: 每行只会有一条输入(比如:C语言可使用gets函数获取一行输入命令的字符串)。a、若输入不符合要求(如:命令字非法,或其他认为输入的错误)均需输出"error"b、每条输出后使用换行符隔开(如后面示例)输出: 1、取号。可获取普通号和vip号码。如初始状态,输入"get",则获取普通号码,执行结果为"1",如再次输入"get vip",则获取VIP号码,执行结果为"vip 2"。如果末尾的2号被删除,则再次调用"get"时应输出"2"。VIP号码有绝对的优先级。普通号和vip号码统一编号,取号均为连续号码。号码从1开始编号,最大为100000.2、叫号。获取当前应该处理用户的号码。例如当前排队号码为1 2 3 4 5 7,当输入"call",执行结果为"1",如1为vip号码,则为"vip 1".如果再连续调用6次,第六次执行结果应为"error" 3、删除号码。客户不想办理时可删除号码,叫号时则跳过此号码。例如当前排队号码为1 2 3 4 5,输入"delete 5",执行结果为"5",如果5为vip则显示"vip 5"。再次输出"delete 5",执行结果为"error" 4、获取当前排队总人数。获取当前排队人数。例如当前排队号码为1 2 3 4 5 6,执行结果为"6" 5、获取在某个号码之前排队的总人数。例如当前排队号码为1 2 3 4 5 7,输入"countN 7",执行结果为"5" 6、重置排号机。例如输入"reset",则重置排号机,进入初始状态,无需输出。 7、退出排号机。例如输入"quit",则退出排号机,无需输出。 样例输入: get get get get vip count countN 1 call quit 样例输出: 1 2 3 vip 4 4 1vip 4 本人实现的思路:构造一个数据链表,用data存当前的位号,vip表示是否为vip号码(1:是,0:否)然后构造相应操作的 |
CopyRight 2018-2019 实验室设备网 版权所有 |