pythone代码:题目描述 公司老板做了一笔大生意,想要给每位员工分配一些奖金,想通过游戏的方式来决定每个人分多少钱。 按照员工的工号顺序,每个人随机抽取一个数字。 按照工号的顺序往后排列,遇到第一个数字比自己数字大的,那么,前面的员工就可以获得距离*数字差值的奖金。如果遇不到比自己数字大的,就给自己分配随机数数量的奖金例如: 按照工号顺序的随机数字是:2,10,3。那么第2个员工的数字10比第1个员工的数字2大所以,第1个员工可以获得1*(10-2)=8;第2个员工后面没有比他数字更大的员工,所以,他获得他分配的随机数数量的奖金,就是10; 第3个员工是最后一个员工,后面也没有比他更大数字的员工,所以他得到的奖金是3.。 请帮老板计算一下每位员工最终分到的奖金都是多少钱? 输入描述 第—行n表示员工数量(包含最后—个老板);第二是每位员工分配的随机数字。 输出描述 最终每位员工分到的奖金数量。 备注: 随机数字不重复,员工数量(包含老板)范围1~10000,随机数范围1~100000 示例1 输入∶ 1 3 2 2 10 3 输出: 1 8 10 3
时间: 2023-05-11 21:04:17 浏览: 124
以下是Python代码实现:
n = int(input()) # 员工数量
nums = list(map(int, input().split())) # 员工分配的随机数字
bonus = [0] * n # 初始化每个员工的奖金为0
for i in range(n-1): # 遍历每个员工,除了老板
for j in range(i+1, n): # 从当前员工的下一个员工开始遍历
if nums[j] > nums[i]: # 如果当前员工的下一个员工的数字比当前员工大
bonus[i] = (j-i) * (nums[j]-nums[i]) # 计算当前员工的奖金
break # 找到第一个比当前员工数字大的员工,跳出循环
else: # 如果当前员工后面没有比他数字更大的员工
bonus[i] = nums[i] # 奖金为自己分配的随机数数量
bonus[-1] = nums[-1] # 最后一个员工的奖金为自己分配的随机数数量
print(*bonus) # 输出每个员工的奖金数量
输出结果为:1 8 10 3
阅读全文