hnldyxx551 发表于 2020-3-15 00:14:59

保龄球的积分问题

一共有10个保龄球按照1 2 3 4的顺序放。
两次机会里没有击倒10个: 第一次4个 第二次两个就按照42来算然后分数是6分
如果第一次就击倒10个,算作X 给30分
如果花了两次击倒10个,写作7/,意味着第一次打了7个第二次10个都到了。给20分
在作业里面已经给了公式
def fold(op, f, n):
if n == 0:
return f(0)
else:
return op(f(n), fold(op, f, n-1))

def sum(term, a, next, b):
if (a > b):
return 0
else:
return term(a) + sum(term, next(a), next, b)

def accumulate(fn, init, lst, get):
if not lst:
return init
else:
return fn(get(lst), accumulate(fn, init, lst, get))
如果我的input是这样子的
def knocked_down(game):
return sum(t1, t2, t3, t4)

>>> knocked_down('XXX9/9/45421/XX')
95
>>> knocked_down('12345/12345/12345/1/')
70
>>> knocked_down('XXXXXXXXXX')
100

hnldyxx551 发表于 2020-3-15 08:10:00

实在不知道该怎么写这个问题

hnldyxx551 发表于 2020-3-15 11:27:36

我不知道怎么用dictionary去写这个问题

hnldyxx551 发表于 2020-3-15 16:25:28

还要difine t1 t2 t3 t4

乘号 发表于 2020-3-20 08:49:05

要不要我帮你@一下某些大佬?

乘号 发表于 2020-3-20 08:49:38

@一个账号
页: [1]
查看完整版本: 保龄球的积分问题