• 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
  • 相关阅读:
    【vue3】05. 跟着官网学习vue3
    Vulkan与OpenGL对比——Vulkan的全新渲染架构
    vue和react的区别
    【D3.js】2.2-给 Circle 元素添加属性
    Java内存溢出的几个区域,注意避坑
    ChatGPT在工业领域的研究与应用探索-数据与工况认知
    【408数据结构与算法】—快速排序(十九)
    springboot+mybatis-plus实现读写分离
    web入门(1)---6.10
    Linux防火墙命令
  • 原文地址:https://blog.csdn.net/tigerisland45/article/details/128068207