扑克牌问题

题目

手里有一副牌,取第一张牌放到桌子上,取第二张牌放到牌堆底部,取第三张牌放到桌子上,取第四张牌放到牌堆底部… 直到手里没有牌了。现在桌子上的牌是从 1 到 n 按顺序排列的,求牌在手里时的顺序是怎样的?

思路

比如一副牌在手里时的顺序是 [1 5 2 4 3],经过上面的规则变换后在桌子上的顺序就是 [1 2 3 4 5],变换过程是这样的:

桌子手里操作
0:[][1 5 2 4 3]– 将 1 放到桌子上,将 5 放到堆底
1:[1][2 4 3 5]– 将 2 放到桌子上,将 4 放到堆底
2:[1 2][3 5 4]– 将 3 放到桌子上,将 5 放到堆底
3:[1 2 3][4 5]– 将 4 放到桌子上,将 5 放到堆底
4:[1 2 3 4][5]– 将 5 放到桌子上
5:[1 2 3 4 5][]

解法:假设牌在手里时的顺序是 [a1 a2 a3 a4],经过下面的变换过程变成了 [a1 a3 a5 a4 a2]

桌子手里
0:[][a1 a2 a3 a4 a5]
1:[a1][a3 a4 a5 a2]
2:[a1 a3][a5 a2 a4]
3:[a1 a3 a5][a4 a2]
4:[a1 a3 a5 a4][a2]
5:[a1 a3 a5 a4 a2][]

最后在桌子上的牌是 [1 2 3 4 5],那么就意味着 a1 = 1, a3 = 2, a5 = 3, a4 = 4, a5 = 2,原来在手里的顺序就是 [1 5 2 4 3]。也就是说只要按题目的规则变换数组,最后数组中的值就是原数组的下标,比如 a5 = 3 就说明 3 在 a5 的位置, a5 原来在索引为 5 的位置。

vector<int> getInitial(vector<int> a)
{
    deque<int> tempDeq;
    vector<int> tempVec;
    vector<int> resultVec;
    int count=0;
    for (int k = 0; k < a.size(); ++k) {
        tempDeq.push_back(a[k]);
    }
    while (!tempDeq.empty())
    {
        if (count%2==0)
        {
            tempVec.push_back(tempDeq.back());
            tempDeq.pop_back();
        } else
        {
            tempDeq.push_front(tempDeq.back());
            tempDeq.pop_back();
        }
        count++;
    }
    resultVec=tempVec;
    for (int i = 0; i < resultVec.size(); ++i) {
        resultVec[tempVec[i]-1]=i+1;
    }
    return resultVec;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值