蓝桥杯第101题 拉马车 C++ Java Python

8 篇文章 0 订阅
6 篇文章 0 订阅

目录

题目

思路和解题方法

复杂度:

c++ 代码

Java 版本(仅供参考)

Python 版本(仅供参考)

代码细节

C++ 版本:

Java 版本:

Python 版本:


题目

思路和解题方法

这个游戏是一个简单的纸牌游戏,两个玩家轮流出牌,每个玩家从自己的牌堆中选择一张牌出牌,直到没有牌为止。具体步骤如下:

  1. 定义两个队列来存储玩家A和玩家B的牌堆。
  2. 玩家轮流出牌,每次出一张牌。
  3. 当任一玩家的牌堆为空时,游戏结束。
  4. 输出剩余的牌堆。

复杂度:

  • 时间复杂度: 代码只需遍历字符串一次,时间复杂度为 O(n),其中 n 是字符串的长度。
  • 空间复杂度: 使用了队列、栈和数组来存储字符,因此空间复杂度为 O(n)。

c++ 代码

#include <iostream>
#include <queue>
#include <stack>
#include <string>
#include <cstring> // 添加这一行来包含 <cstring> 头文件以使用 memset 函数
using namespace std;

queue<char> a, b; // 修改为队列存储字符
stack<char> s;
int check[256]; // 修改为使用数组存储字符出现情况

int main() {
    string aa, bb;
    int who = 1;
    cin >> aa >> bb;

    // 将字符串转换为队列
    for (int i = 0; i < aa.size(); i++) {
        a.push(aa[i]);
    }
    for (int i = 0; i < bb.size(); i++) {
        b.push(bb[i]);
    }

    while (!a.empty() && !b.empty()) {
        if (who == 1) {
            s.push(a.front());
            a.pop();
            if (check[s.top()]) {
                who = 1;
                char tmp = s.top();
                a.push(tmp); // 修正为将字符 tmp 压入队列 a
                s.pop();
                while (s.top() != tmp) {
                    a.push(s.top());
                    check[s.top()] = 0;
                    s.pop();
                }
                a.push(tmp);
                check[tmp] = 0;
                s.pop();
            }
            else {
                who = 2;
                check[s.top()] = 1;
            }
        }
        else {
            s.push(b.front());
            b.pop();
            if (check[s.top()]) {
                who = 2;
                char tmp = s.top();
                b.push(tmp); // 修正为将字符 tmp 压入队列 b
                s.pop();
                while (s.top() != tmp) {
                    b.push(s.top());
                    check[s.top()] = 0;
                    s.pop();
                }
                b.push(tmp);
                check[tmp] = 0;
                s.pop();
            }
            else {
                who = 1;
                check[s.top()] = 1;
            }
        }
    }
    while (!a.empty()) {
        cout << a.front();
        a.pop();
    }
    while (!b.empty()) {
        cout << b.front();
        b.pop();
    }
    return 0;
}

Java 版本(仅供参考)

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        Queue<Character> a = new LinkedList<>();
        Queue<Character> b = new LinkedList<>();
        Stack<Character> s = new Stack<>();
        int[] check = new int[256];

        String aa = scanner.next();
        String bb = scanner.next();

        int who = 1;

        for (char c : aa.toCharArray())
            a.offer(c);

        for (char c : bb.toCharArray())
            b.offer(c);

        while (!a.isEmpty() && !b.isEmpty()) {
            if (who == 1) {
                s.push(a.poll());
                if (check[s.peek()] != 0) {
                    who = 1;
                    char tmp = s.peek();
                    a.offer(tmp);
                    s.pop();
                    while (s.peek() != tmp) {
                        a.offer(s.peek());
                        check[s.peek()] = 0;
                        s.pop();
                    }
                    a.offer(tmp);
                    check[tmp] = 0;
                    s.pop();
                } else {
                    who = 2;
                    check[s.peek()] = 1;
                }
            } else {
                s.push(b.poll());
                if (check[s.peek()] != 0) {
                    who = 2;
                    char tmp = s.peek();
                    b.offer(tmp);
                    s.pop();
                    while (s.peek() != tmp) {
                        b.offer(s.peek());
                        check[s.peek()] = 0;
                        s.pop();
                    }
                    b.offer(tmp);
                    check[tmp] = 0;
                    s.pop();
                } else {
                    who = 1;
                    check[s.peek()] = 1;
                }
            }
        }

        while (!a.isEmpty())
            System.out.print(a.poll());

        while (!b.isEmpty())
            System.out.print(b.poll());
    }
}

Python 版本(仅供参考)

from collections import deque

aa = input()
bb = input()

a = deque(aa)
b = deque(bb)
s = []
check = [0] * 256
who = 1

while a and b:
    if who == 1:
        s.append(a.popleft())
        if check[ord(s[-1])] != 0:
            who = 1
            tmp = s[-1]
            a.append(tmp)
            s.pop()
            while s[-1] != tmp:
                a.append(s[-1])
                check[ord(s[-1])] = 0
                s.pop()
            a.append(tmp)
            check[ord(tmp)] = 0
            s.pop()
        else:
            who = 2
            check[ord(s[-1])] = 1
    else:
        s.append(b.popleft())
        if check[ord(s[-1])] != 0:
            who = 2
            tmp = s[-1]
            b.append(tmp)
            s.pop()
            while s[-1] != tmp:
                b.append(s[-1])
                check[ord(s[-1])] = 0
                s.pop()
            b.append(tmp)
            check[ord(tmp)] = 0
            s.pop()
        else:
            who = 1
            check[ord(s[-1])] = 1

print(''.join(a) + ''.join(b))

代码细节:

C++ 版本:

  1. 使用 std::queue<char>std::stack<char> 分别代表队列和栈。这些数据结构需要包含 <queue><stack> 头文件。
  2. 使用 std::string 类型代表输入的字符串,字符串的读取使用 cin
  3. 使用 std::memset 函数需要包含 <cstring> 头文件。
  4. 使用 std::cout 输出结果。

Java 版本:

  1. 使用 java.util.Queue<Character>java.util.Stack<Character> 分别代表队列和栈。
  2. 使用 java.util.Scanner 类型进行输入。
  3. 使用 System.out.println() 输出结果。

Python 版本:

  1. 使用 collections.deque 代表队列。
  2. 使用列表代表栈。
  3. 使用 input() 函数进行输入。
  4. 使用 print() 函数输出结果。

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦  >人<  。

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值