<pre name="code" class="python">def merge(line):
"""
Function that merges a single row or column in 2048.
"""
resultlist=[]
for item in range(len(line)):
resultlist.append(0)
#slide non-zero tiles to the front of list
times=-1
for item in range(len(line)):
if not line[item] == 0:
times += 1
resultlist.insert(times, line[item])
resultlist.pop()
#merge the same number
if len(resultlist) > 1:
for item in range(1, len(resultlist)):
if resultlist[item-1] == resultlist[item]:
resultlist[item-1] = resultlist[item-1] * 2
resultlist.pop(item)
resultlist.append(0)
return resultlist
功能merge:将list中的非0的数值移到list前端,并且相邻数值合并。 e.g [2,2,0,4] 返还[4,4,0,0]
原理:运行任意 list(line), 创建新的 list (resultlist) 并给予其与原来line相同 数量的 元素 (值为 0)。 loop原list,如果元素值不等于0, 将该元素值插入新的list并且移除新list中最后一个值为0的元素,保持新list的长度与原有的相同。接下来loop新的list,如果list中的元素值与loop前一项元素值相等,那么前一项元素值翻倍,同时移除loop时那一项的元素值,同时在末尾添加数值为0 的 元素(保持list原有长度)。小记:在loop新list时,考虑到 list的长度可能只有1 (e.g. [4]) 或者list最前项和最后项相等。 如果 loop时 从 0开始,那么结果就会有误差。 所以在 loop新list下, 设置loop从 1开始, 这样就解决了可能 出现的问题。