• LQ0266 巧排扑克牌【模拟】


    题目来源:蓝桥杯2012初赛 C++ C组D题

    题目描述
    本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

    小明刚上小学,学会了第一个扑克牌“魔术”,到处给人表演。魔术的内容是这样的:

    他手里握着一叠扑克牌:A,2,…J,Q,K 一共 13 张。他先自己精心设计它们的顺序,然后正面朝下拿着,开始表演。

    只见他先从最下面拿一张放到最上面,再从最下面拿一张翻开放桌子上,是 A;然后再从最下面拿一张放到最上面,再从最下面拿一张翻开放桌子上,是 2;…如此循环直到手中只有一张牌,翻开放桌子上,刚好是 K。

    这时,桌上牌的顺序是:A,2,3,4,5,6,7,8,9,10,J,Q,K。

    请你计算一下,小明最开始的时候手里牌的顺序是怎样的。

    把结果写出来,逗号分割,小明“魔术”开始时,最下面的那张牌输出为第一个数据。

    问题分析
    用模拟法来实现,用队列来模拟,再做一下逆计算。
    题目BUG啊!逗号隔开,但是逗号后面需要有一个空格。

    AC的C++语言程序如下:

    /* LQ0266 巧排扑克牌 */
    
    #include 
    #include 
    
    using namespace std;
    
    int cards[13 + 1];
    char JQK[] = "JQK";
    
    int main()
    {
        queue<int> q, q2;
        for (int i = 1; i <= 13; i++)
            q.push(i);
    
        // 模拟
        while (q.size() > 1) {
            q.push(q.front());
            q.pop();
            q2.push(q.front());
            q.pop();
        }
        q2.push(q.front());
    
        int k = 1;
        while (!q2.empty()){
            cards[q2.front()] = k++;
            q2.pop();
        }
    
        // 输出结果
        if (cards[1] == 1) printf("A");
        else if (cards[1] <= 10) printf("%d", cards[1]);
        else printf("%c", JQK[cards[1] - 11]);
        for (int i = 2; i <= 13; i++) {
            printf(", ");
            if (cards[i] == 1) printf("A");
            else if (cards[i] <= 10) printf("%d", cards[i]);
            else printf("%c", JQK[cards[i] - 11]);
        }
    
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
  • 相关阅读:
    植物大战僵尸变态辅助开发系列教程(E语言实现和VC6实现)(上)
    axios在vue3.x中的基础入门使用
    springboot-mybatisplus-redis二级缓存
    LNMP及论坛的搭建
    基于遗传优化的货柜货物摆放优化问题求解matlab仿真
    Java实现FTP下载文件到客户端(浏览器)
    MySQL数据库主从同步,一致性解决方案
    深度学习硬件配置推荐(kaggle学习)
    Activity(页面)的生命周期
    迅为itop-3568开发板qt学习手册上新
  • 原文地址:https://blog.csdn.net/tigerisland45/article/details/128068207