平常喜欢看这种逻辑类的题目,所以昨天晚上刷到以下这道题

题目:

 魔术师发牌问题的简介:一位魔术师掏出一叠扑克牌,魔术师取出其中13张黑桃,洗好后,把牌面朝下。说:“我不看牌,只数一数就能知道每张牌是什么?”魔术师口中念一,将第一张牌翻过来看正好是A;魔术师将黑桃A放到桌上,继续数手里的余牌,第二次数1,2,将第一张牌放到这叠牌的下面,将第二张牌翻开,正好是黑桃2,也把它放在桌子上。第三次数1,2,3,前面二张牌放到这叠牌的下面,取出第三张牌,正好是黑桃3,这样依次将13张牌翻出,全部都准确无误。求解:魔术师手中牌的原始顺序是什么样子的? 

答案:

由于ES6用的不太熟,可能会有冗杂

//声明扑克牌总数
var arr=[0,0,0,0,0,0,0,0,0,0,0,0,0]
//当前第一张牌索引
var index=0;
for (var i = 1; i <= 13; i++) {
    // 所有未确定的扑克牌的索引集合
    var indexarr=arr.map((a,index)=>{if(a==0){return index}}).filter((a)=>(a!=undefined))
    //当前第一张牌在所有未确定的扑克牌的索引集合中的索引
    index=parseInt((index+i-1)%indexarr.length)
    //赋值
    arr[indexarr[index]]=i
};
//输出
console.log(arr)

如有更好解决方案欢迎讨论!

原创转载请注明出处!小猿爱编程

11-25 21:55