华为机试-python

HJ89

1 总体说明
考生需要模拟实现一个简单的自动售货系统,实现投币、购买商品、退币、查询库存商品及存钱盒信息的功能。
系统初始化时自动售货机中商品为6种商品,商品的单价参见1.1规格说明,存钱盒内放置1元、2元、5元、10元钱币,商品数量和钱币张数通过初始化命令设置,参见2.1 系统初始化。
1.1规格说明

  1. 商品:每种商品包含商品名称、单价、数量三种属性,其中商品名不重复。考生不能修改商品名称和单价,初始化命令设置商品数量。这些信息在考试框架中进行定义,考生在实现功能代码时可直接使用。
    商品 名称
    单价
    数量
    A1 2 X
    A2 3 X
    A3 4 X
    A4 5 X
    A5 8 X
    A6 6 X
  2. 存钱盒信息:钱币面额、张数两种属性。初始化命令设置各种面额钱币张数。这些信息在考试框架中进行定义,考生在实现功能代码时可直接使用。
    钱币面额
    张数
    10元
    X
    5元
    X
    2元 X
    1元 X
  3. 退币原则 :
  1. 根据系统存钱盒内钱币的 信息 ,按钱币总张数最少的原则进行退币。
  2. 如果因零钱不足导致不能退币,则尽最大可能退币,以减少用户损失。
    例如:假设存钱盒内只有4张2元,无其它面额钱币。如果需要退币7元,系统因零钱不足无法退币,则继续尝试退币6元,最终系统成功退币3张2元,用户损失1元钱币。
  1. 投币操作说明:每次投币成功,投入的钱币面额累加到投币余额;同时,本次投入的钱币放入存钱盒中,存钱盒相应面额钱币增加。
  2. 投币余额:指当前自动售货机中用户剩余的可购买商品的钱币总额;例如:投入2元面额的钱币,投币余额增加2元;购买一件价格2元的商品,投币余额减少2元;
  3. 投币余额约束:投币余额不能超过10元。
  4. 退币操作说明:退币操作需要遵守 退币原则 ;退币成功后,投币余额清零,同时扣除存钱盒相应的金额。
  5. 购买商品操作说明:一次仅允许购买一件商品;购买商品成功后,自动售货机中对应商品数量减1,投币余额扣除本次购买商品的价格。
    2 操作说明
    命令字与第一个参数间使用一个空格分隔,多条命令采用分号隔开。考试系统会对输入命令格式进行处理,考生不需要关注输入命令格式的合法性,只需要实现命令处理函数。
    2.1 系统初始化
    命令格式:
    r A1 数量 -A2 数量 -A3 数量 -A4 数量 -A5 数量 -A6 数量 1 元张数 -2 元张数 -5 元张数 -10 元张数
    参数名称
    参数说明
    类型
    取值范围
    A1数量
    商品A1数量
    整数
    [0,10]
    A2数量
    商品A2数量
    整数
    [0,10]
    A3数量
    商品A3数量
    整数
    [0,10]
    A4数量
    商品A4数量
    整数
    [0,10]
    A5数量
    商品A5数量
    整数
    [0,10]
    A6数量
    商品A6数量
    整数
    [0,10]
    1元张数
    面额1元钱币张数
    整数
    [0,10]
    2元张数
    面额2元钱币张数
    整数
    [0,10]
    5元张数
    面额5元钱币张数
    整数
    [0,10]
    10元张数
    面额10元钱币张数
    整数
    [0,10]
    商品和各种面额钱币取值范围只是作为初始化命令的限制,其它场景下不限制取值范围;考试框架已经实现取值范围的检查,考生不需要关注。
    功能说明:设置自动售货机中商品数量和存钱盒各种面额的钱币张数;
    约束说明:系统在任意阶段均可执行r初始化系统;考生不需要关注参数的合法性,不需要关注增加或缺少参数的场景;
    输出说明:输出操作成功提示(执行完r命令后系统会自动输出操作结果,考生不需要再次调用输出函数),例:
    命令 输出 含义
    r 6-5-4-3-2-1 4-3-2-1; S001:Initialization is successful 初始化成功
    2.2 投币
    命令格式:p 钱币面额
    功能说明:
    (1) 如果投入非1元、2元、5元、10元的钱币面额(钱币面额不考虑负数、字符等非正整数的情况),输出“E002:Denomination error”;
    (2) 如果存钱盒中1元和2元面额钱币总额小于本次投入的钱币面额,输出“E003:Change is not enough, pay fail”,但投入1元和2元面额钱币不受此限制。
    (3) 如果投币余额大于10元,输出“E004:Pay the balance is beyond the scope biggest”;
    (4) 如果自动售货机中商品全部销售完毕,投币失败。输出“E005:All the goods sold out”;
    (5) 如果投币成功,输出“S002:Pay success,balance=X”;
    约束说明:
    (1) 系统在任意阶段都可以投币;
    (2) 一次投币只能投一张钱币;
    (3) 同等条件下,错误码的优先级:E002 > E003 > E004 > E005;
    输出说明:如果投币成功,输出“S002:Pay success,balance=X”。
    例:
    命令
    输出
    p 10;
    S002:Pay success,balance=10
    2.3 购买商品
    命令格式:b 商品名称
    功能说明:
    (1) 如果购买的商品不在商品列表中,输出“E006:Goods does not exist”;
    (2) 如果所购买的商品的数量为0,输出“E007:The goods sold out”;
    (3) 如果投币余额小于待购买商品价格,输出“E008:Lack of balance”;
    (4) 如果购买成功,输出“S003:Buy success,balance=X”;
    约束说明:
    (1) 一次购买操作仅能购买一件商品,可以多次购买;
    (2) 同等条件下,错误码的优先级:E006 > E007 > E008;
    输出说明:
    如果购买成功,输出“S003:Buy success,balance=X”。
    例:
    命令
    输出
    b A1;
    S003:Buy success,balance=8
    2.4 退币
    命令格式:c
    功能说明:
    (1) 如果投币余额等于0的情况下,输出“E009:Work failure”;
    (2) 如果投币余额大于0的情况下,按照 退币原则 进行“找零”,输出退币信息;
    约束说明:
    (1) 系统在任意阶段都可以退币;
    (2) 退币方式必须按照 退币原则 进行退币;
    输出说明:如果退币成功,按照 退币原则 输出退币信息。
    例,退5元钱币:
    命令
    输出
    c;
    1 yuan coin number=0
    2 yuan coin number=0
    5 yuan coin number=1
    10 yuan coin number=0
    2.5 查询
    命令格式:q 查询类别
    功能说明:
    (1) 查询自动售货机中商品信息,包含商品名称、单价、数量。 根据商品数量从大到小进行排序;商品数量相同时,按照商品名称的先后顺序进行排序 。
    例如:A1的商品名称先于A2的商品名称,A2的商品名称先于A3的商品名称。
    (2) 查询存钱盒信息,包含各种面额钱币的张数;
    (3) 查询类别如下表所示:
    查询类别
    查询内容
    0
    查询商品信息
    1 查询存钱盒信息
    如果“查询类别”参数错误,输出“E010:Parameter error”。“查询类别”参数错误时,不进行下面的处理;
    输出说明:
    “查询类别”为0时,输出自动售货机中所有商品信息(商品名称单价数量)例:
    命令
    输出
    q 0;
    A1 2 6
    A2 3 5
    A3 4 4
    A4 5 3
    A5 8 2
    A6 6 0
    “查询类别”为1时,输出存钱盒信息(各种面额钱币的张数),格式固定。例:
    命令
    输出
    q 1;
    1 yuan coin number=4
    2 yuan coin number=3
    5 yuan coin number=2
    10 yuan coin number=1
    输入描述:
    依照说明中的命令码格式输入命令。
    输出描述:
    输出执行结果
    示例1
    输入
    r 1-1-1-1-1-1 10-5-2-1;p 1;q 1;
    输出
    S001:Initialization is successful
    S002:Pay success,balance=1
    1 yuan coin number=11
    2 yuan coin number=5
    5 yuan coin number=2
    10 yuan coin number=1
import sys
while True:
    try:
        pricegoods={'A1':2,'A2':3,'A3':4,'A4':5,'A5':8,'A6':6}
        pricemoney=[1,2,5,10]
        numgoods={'A1':0,'A2':0,'A3':0,'A4':0,'A5':0,'A6':0}
        nummoney=[0]*4
        balance=0
        
        def printcoin(number):
            print('1 yuan coin number=%s'%coinback[0])
            print('2 yuan coin number=%s'%coinback[1])
            print('5 yuan coin number=%s'%coinback[2])
            print('10 yuan coin number=%s'%coinback[3])
        def printgoods(number):
            number=sorted(numgoods,key=lambda a:a[1],reverse=True)
            for i in range(6):
                print (numgoods[i][0]+' '+str(pricegoods[numgoods[i][0]])+' '+str(numgoods[i][0]))
        line=raw_input().split(';')[:-1]
        for i in line:
            func=i.split()
            if func[0]=='r':
                goods=func[1].split('-')
                money=func[2].split('-')
                
                for i in range(6):
                    numgoods['A'+str(i+1)]+=int(goods[i])
                for i in range(4):
                    nummoney[i]+=int(money[i])
                
                print('S001:Initialization is successful')
            elif func[0]=='p':
                num=int(func[1])
                if num not in pricemoney:
                    print('E002:Denomination error')
                elif num in [5,10] and (nummoney[0]+nummoney[1]*2)<num:
                    print('E003:Change is not enough, pay fail')
                elif num==10 and balance>10:
                    print('E004:Pay the balance is beyond the scope biggest')
                elif numgoods['A1']==numgoods['A2']==numgoods['A3']==numgoods['A4']==numgoods['A5']==numgoods['A6']==0:
                    print('E005:All the goods sold out')
                else:
                    nummoney[pricemoney.index(num)]+=1
                    balance+=num
                    print('S002:Pay success,balance=%s'%balance)
            elif func[0]=='b':
                good=func[1]
                if good not in ['A1','A2','A3','A4','A5','A6']:
                    print('E006:Goods does not exist')
                elif numgoods[good]==0:
                    print('E007:The goods sold out')
                elif balance<pricegoods[good]:
                    print('E008:Lack of balance')
                else:
                    balance-=pricegoods[good]
                    numgoods[good]-=1
                    print('S003:Buy success,balance=%s'%balance)
            elif func[0]=='c':
                if balance==0:
                    sys.stdout.write('E009:Work failure')
                else:
                    coinback=[0]*4
                    for i in range(-1,-5,-1):
                        coinback[i]+=min(int(balance/pricemoney[i]),nummoney[i])
                        balance-=pricemoney[i]*coinback[i]
                        nummoney[i]-=coinback[i]
                    printcoin(coinback)
                    balance=0
            elif func[0]=='q':
                if func[1]=='0':
                    pricegoods(numgoods)
                elif func[1]=='1':
                    printcoin(nummoney)
            else:
                    sys.stdout.write('E010:Parameter error')
    except:
        break

补充:

1.print(’ 字符串’)
2.sys.stdout.write(’ ‘+’\n’)=print(’ ')
3.根据字典中值的大小,对字典中的项排序
sorted(d.items(), key=lambda x: x[1]) 中 d.items() 为待排序的对象;key=lambda x: x[1] 为对前面的对象中的第二维数据(即value)的值进行排序。 key=lambda 变量:变量[维数] 。维数可以按照自己的需要进行设置。

维数以字符串来表示
将列表中的age由大到小排序
alist = [{‘name’:‘a’,‘age’:20},{‘name’:‘b’,‘age’:30},{‘name’:‘c’,‘age’:25}]
b=sorted(alist,key=lambda x:x[‘age’],reverse=True)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
华为OD机试真题要求使用Python实现分班功能,下面我将简要说明实现的思路。 首先我们需要读取输入的学生信息,包括姓名和成绩。可以使用Python输入函数`input()`来实现,要求输入的学生信息按照一定格式排列,例如每行一个学生信息,姓名和成绩之间使用空格分隔。 我们可以定义一个空的字典来存储学生信息,姓名作为key,成绩作为value。我们可以使用Python的字典数据类型来实现,`student_dict = {}`。 然后,我们可以根据成绩对学生进行排序,可以使用Python的内置函数`sorted()`对字典的value进行排序,注意我们需要通过`student_dict.items()`将字典转换为可排序的列表。 接着我们需要根据排序后的学生列表来分班,根据题目要求,每班的人数是相同的,假设为n。有两种常见的分班方式: 1. 按照学生的顺序,依次将学生分到不同的班级,当分到第n个学生时,再将学生分到下一个班级。可以使用取余运算符`%`来实现这个过程。 2. 先将学生按照成绩分组,成绩相同的学生放在一起,然后再将每组学生按照上述方式分到不同的班级。 最后,我们需要输出分班结果,可以使用Python的格式化输出语句将学生信息打印出来,例如`print("班级1: " + str(class1))`。 以上是我对华为OD机试真题的大致思路,具体的代码实现需要考虑一些细节问题,并根据实际的需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值