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

2024-04-07 07:52
文章标签 java python c++ 蓝桥 101 马车

本文主要是介绍蓝桥杯第101题 拉马车 C++ Java Python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

题目

思路和解题方法

复杂度:

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 压入队列 as.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 压入队列 bs.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 dequeaa = input()
bb = input()a = deque(aa)
b = deque(bb)
s = []
check = [0] * 256
who = 1while a and b:if who == 1:s.append(a.popleft())if check[ord(s[-1])] != 0:who = 1tmp = s[-1]a.append(tmp)s.pop()while s[-1] != tmp:a.append(s[-1])check[ord(s[-1])] = 0s.pop()a.append(tmp)check[ord(tmp)] = 0s.pop()else:who = 2check[ord(s[-1])] = 1else:s.append(b.popleft())if check[ord(s[-1])] != 0:who = 2tmp = s[-1]b.append(tmp)s.pop()while s[-1] != tmp:b.append(s[-1])check[ord(s[-1])] = 0s.pop()b.append(tmp)check[ord(tmp)] = 0s.pop()else:who = 1check[ord(s[-1])] = 1print(''.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() 函数输出结果。

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

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

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

这篇关于蓝桥杯第101题 拉马车 C++ Java Python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/882039

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

一文深入详解Python的secrets模块

《一文深入详解Python的secrets模块》在构建涉及用户身份认证、权限管理、加密通信等系统时,开发者最不能忽视的一个问题就是“安全性”,Python在3.6版本中引入了专门面向安全用途的secr... 目录引言一、背景与动机:为什么需要 secrets 模块?二、secrets 模块的核心功能1. 基

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

python常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM