题解 | #自动售货系统#

自动售货系统

https://www.nowcoder.com/practice/cd82dc8a4727404ca5d32fcb487c50bf?tpId=37&tags=&title=&difficulty=0&judgeStatus=0&rp=1&sourceUrl=%2Fexam%2Foj%2Fta%3FtpId%3D37

# 难倒是不难,就是有点麻烦,题目长,要按部就班地写
import sys

inits = []
commands = []

def withdraw(cash_remain, pocket, out={1:0, 2:0, 5:0, 10:0}):
    coins = [10, 5, 2, 1]
    i = 0
    while True:
        if i < 4:
            coin = coins[i]
            if cash_remain >= coin and pocket[coin] > 0:
                cash_remain -= coin
                out[coin] += 1
                pocket[coin] -= 1
            else:
                i += 1
        if sum(pocket.values()) == 0 or cash_remain == 0:
            break
    return cash_remain, pocket, out

for line in sys.stdin:
    line = line.strip()
    if line:
        tmp = ''
        cmds = ''
        for i in range(len(line)):
            if line[i] != ';':
                tmp += line[i]
            else:
                cmds = line[i+1:-1]
                break
        # print(tmp)
        # print(cmds)
        tmp = tmp.split()
        tmp[1:] = [tmp[1].split('-'), tmp[2].split('-')]
        inits = tmp
        cmds = cmds.split(';')
        # print(cmds)
        commands = cmds

# print(inits, commands)
goods = {'A'+str(i):int(inits[1][i-1]) for i in range(1, len(inits[1])+1)}
prices = {'A'+str(i+1):v for i, v in enumerate([2, 3, 4, 5, 8, 6])}
pocket = {1:int(inits[2][0]), 2:int(inits[2][1]), 5:int(inits[2][2]), 10:int(inits[2][3])}
cash_remain = 0
if inits[0] == 'r':
    print('S001:Initialization is successful')

# print(goods, prices, pocket)

for cmd in commands:
    if cmd[0] == 'p':
        cash = int(cmd[2:])
        if cash not in pocket:
            print('E002:Denomination error')
        else:
            pocket_1_2 = pocket[1] * 1 + pocket[2] * 2
            goods_num = sum(goods.values())
            if cash > pocket_1_2:
                print('E003:Change is not enough, pay fail')
            elif goods_num == 0:
                print('E005:All the goods sold out')
            else:
                cash_remain += cash
                pocket[cash] += 1
                print(f'S002:Pay success,balance={cash_remain}')
    elif cmd[0] == 'b':
        good = cmd[2:]
        if good not in goods:
            print('E006:Goods does not exist')
        elif goods[good] == 0:
            print('E007:The goods sold out')
        elif cash_remain < prices[good]:
            print('E008:Lack of balance')
        else:
            goods[good] -= 1
            cash_remain -= prices[good]
            print(f'S003:Buy success,balance={cash_remain}')
    elif cmd[0] == 'c':
        if cash_remain == 0:
            print('E009:Work failure')
        else:
            # print('start withdraw', cash_remain, pocket)
            iout = {1:0, 2:0, 5:0, 10:0}
            remain_cash, remain_pocket, out = withdraw(cash_remain, pocket, iout)
            cash_remain, pocket = remain_cash, remain_pocket
            # print('end withdraw', cash_remain, pocket)
            for i in out:
                print(str(i) + ' yuan coin number=' + str(out[i]))
    elif cmd[0] == 'q':
        flag = cmd[2:]
        if flag not in ['0', '1']:
            print('E010:Parameter error')
        elif flag == '0':
            goods_out = [[good, prices[good], goods[good]] for good in goods]
            goods_out.sort(key=lambda x: x[2], reverse=True)
            for good in goods:
                print(good + ' ' + str(prices[good]) + ' ' + str(goods[good]))
        else:
            for coin in pocket:
                print(str(coin) + ' yuan coin number=' + str(pocket[coin]))

全部评论

相关推荐

迷茫的大四🐶:价格这么低都能满了?
点赞 评论 收藏
分享
09-13 08:41
服装/纺织设计
那一天的Java_J...:你第一次参加面试吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 你的mentor是什么样的人? #
4418次浏览 33人参与
# 你觉得mentor喜欢什么样的实习生 #
10659次浏览 297人参与
# 智慧芽求职进展汇总 #
25824次浏览 109人参与
# 帮我看看,领导说这话什么意思? #
6595次浏览 26人参与
# 26届秋招公司红黑榜 #
13069次浏览 44人参与
# 怎么给家人解释你的工作? #
1587次浏览 17人参与
# 平安产险科技校招 #
2422次浏览 0人参与
# 没有家庭托举的我是怎么找工作的 #
12612次浏览 160人参与
# 求职低谷期你是怎么度过的 #
5394次浏览 96人参与
# 实习必须要去大厂吗? #
146803次浏览 1541人参与
# 从哪些方向判断这个offer值不值得去? #
6719次浏览 95人参与
# 同bg的你秋招战况如何? #
158865次浏览 927人参与
# 度小满求职进展汇总 #
10191次浏览 53人参与
# 校招泡的最久的公司是哪家? #
4794次浏览 23人参与
# 面试紧张时你会有什么表现? #
1782次浏览 21人参与
# 你有哪些缓解焦虑的方法? #
37196次浏览 835人参与
# 你喜欢工作还是上学 #
77610次浏览 860人参与
# 入职第一天,你准备什么时候下班 #
85510次浏览 467人参与
# 秋招想进国企该如何准备 #
97743次浏览 487人参与
# 简历无回复,你会继续海投还是优化再投? #
103613次浏览 819人参与
# 机械人的工作环境真的很差吗 #
25075次浏览 119人参与
# 独居后,你的生活是更好了还是更差了? #
28145次浏览 263人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务