基于Python实现扑克牌面试题
这篇文章主要介绍了基于Python实现扑克牌面试题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
据说是腾讯的面试题,以下是要求:
一副从1到n的牌,每次从牌堆顶取一张放桌子上,再取一张放牌堆底,直到手中没牌。根据桌上的牌堆顺序,输出原先手中牌堆的顺序数组。
实现思路:
1、首先定义一个2维数组,代表最后桌上的牌堆排列情况。内部数组flist[i][0],flist[i][1]分别表示牌堆的排序和牌面的序号。
2、分n为奇数或偶数2种情况,用for循环逆推出原牌组的的顺序值(顺序为小数在下,大数在上)
3、对新数组用顺序值进行逆向排序后,输出由牌面的序号组成的数组
defcl(n): flst=[]#用数组flst定义最后桌上的牌堆顺序 foriinrange(1,n+1): flst.append([i,i]) ifn%2==0:#n为偶数情况 fortinrange(1,int(n/2)+1):#t为循环次数,代表一次取牌放牌顶+牌底的过程 flst[n-t][0]=2*t-1 flst[t-1][0]=2*t else:#n为奇数情况 flst[0][0]=1#新牌堆首张牌必定为原牌堆的最后一张 fortinrange(1,n//2+1): flst[n-t][0]=2*t flst[t][0]=2*t+1 olst=sorted(flst,key=lambdax:x[0],reverse=True)#对二维数组进行排序 res=[i[1]foriinolst]#求得原牌组牌号 returnres
最后测试打印结果
print(cl(10)) print(cl(11))
输出正确
[5,6,4,7,3,8,2,9,1,10] [6,7,5,8,4,9,3,10,2,11,1]
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。