蓝桥杯第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

相关文章

Java StringBuilder 实现原理全攻略

《JavaStringBuilder实现原理全攻略》StringBuilder是Java提供的可变字符序列类,位于java.lang包中,专门用于高效处理字符串的拼接和修改操作,本文给大家介绍Ja... 目录一、StringBuilder 基本概述核心特性二、StringBuilder 核心实现2.1 内部

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

Java中字符编码问题的解决方法详解

《Java中字符编码问题的解决方法详解》在日常Java开发中,字符编码问题是一个非常常见却又特别容易踩坑的地方,这篇文章就带你一步一步看清楚字符编码的来龙去脉,并结合可运行的代码,看看如何在Java项... 目录前言背景:为什么会出现编码问题常见场景分析控制台输出乱码文件读写乱码数据库存取乱码解决方案统一使

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与