蓝桥杯 10.拉马车

拉马车

原题目链接

题目描述

小时候你玩过纸牌游戏吗?

有一种叫做 "拉马车" 的游戏,规则简单但非常吸引小朋友。

游戏规则简述如下:

假设参加游戏的小朋友是 AB,游戏开始时,他们得到的随机纸牌序列如下:

  • A 方:[K, 8, X, K, A, 2, A, 9, 5, A]
  • B 方:[2, 7, K, 5, J, 5, Q, 6, K, 4]

其中 X 表示 10,忽略花色。

游戏从 A 方开始,A、B 双方轮流出牌:

  1. 每次出牌从自己的纸牌队列头部拿出一张放在桌上(压在已有牌堆最上方);
  2. 若当前出的牌在桌上的已有牌中出现过同牌点,则**从那一张牌开始到当前牌之间的所有纸牌(包括当前)**归该玩家所有;
  3. 将这些纸牌按出现在桌上的逆序加入自己手牌队尾;
  4. 获胜方继续出下一张牌。

若当前出的牌在桌面上没有同点牌,则另一方继续出牌。

结束条件:

  • 当某一方打出最后一张牌,且无法赢得桌上任何牌时,游戏立即结束。
  • 任务是判断谁赢了,并输出其最终手中纸牌的顺序

若游戏无法结束(死循环),输出 -1


输入描述

  • 输入 2 行,每行为一个字符串,表示 A 和 B 初始牌序。
  • 字符串中每个字符为:2~9AJQKX(代表10)。
  • 输入字符串长度不超过 30。

输出描述

  • 如果游戏有赢家,输出赢家手中纸牌的字符串(按顺序);
  • 如果游戏无法结束,输出 -1

输入样例

in 复制代码
96J5A898QA
6278A7Q973

输出样例

out 复制代码
2J9A7QA6Q6889977

c++代码

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int main() {
    string a, b;
    cin >> a >> b;
    int m = a.size(), n = b.size(), l = 0, r = 0, key = 0;
    stack<char> st;
    unordered_set<char> mp;
    while(true) {
        if (l == a.size()) {
            int len = m + n - st.size();
            cout << b.substr(b.size() - len);
            return 0;
        }
        if (r == b.size()) {
            int len = m + n - st.size();
            cout << a.substr(a.size() - len);
            return 0;
        }
        if (key % 2 == 0) {
            if (mp.find(a[l]) == mp.end()) st.push(a[l]), mp.insert(a[l]);
            else {
                key--, a += a[l];
                while(!st.empty()) {
                    char c = st.top();
                    a += c;
                    mp.erase(c), st.pop();
                    if (c == a[l]) break;
                }
            }
            l++;
        }
        else {
            if (mp.find(b[r]) == mp.end()) st.push(b[r]), mp.insert(b[r]);
            else {
                key--, b += b[r];
                while(!st.empty()) {
                    char c = st.top();
                    b += c;
                    mp.erase(c), st.pop();
                    if (c == b[r]) break;
                }
            }
            r++;
        }
        key++;
    }
    return 0;
}//by wqs

思路解析

本题是一个模拟题,因为字符串长度不超过30,所以直接暴力模拟就行。

相关推荐
生成论实验室2 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第十篇:识势应势——从认知到行动的完整闭环
人工智能·算法·架构·创业创新·安全架构
risc1234564 分钟前
SegmentTermsEnum#postings 和 IntersectTermsEnum#postings
算法·lucene
阿Y加油吧7 分钟前
二刷 LeetCode:两道经典贪心题复盘
算法·leetcode·职场和发展
顺顺 尼7 分钟前
程序地址空间和进程的一些操作
算法
Java成神之路-10 分钟前
【LeetCode 刷题笔记】35. 搜索插入位置 | 二分查找经典入门题
算法·leetcode
CSCN新手听安11 分钟前
【Qt】Qt窗口(五)QDialog对话框的使用,点击按钮弹出新的对话框,自定义对话框界面,模态对话框model
开发语言·c++·qt
SunnyByte12 分钟前
数据结构——算法效率
数据结构
计算机魔术师14 分钟前
【职场观察 | 技术人处境】五一假期结束,职场两边同时加速——“简历热“和“优化潮“背后的结构性逻辑
人工智能·面试·职场和发展·cot 推理·技术人求职·ai替代逻辑
晴夏。15 分钟前
c++调用lua的方法
c++·游戏引擎·lua·ue
Lhan.zzZ8 小时前
笔记_2026.4.28_004
c++·ide·笔记·qt