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

相关文章

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

Spring Boot 处理带文件表单的方式汇总

《SpringBoot处理带文件表单的方式汇总》本文详细介绍了六种处理文件上传的方式,包括@RequestParam、@RequestPart、@ModelAttribute、@ModelAttr... 目录方式 1:@RequestParam接收文件后端代码前端代码特点方式 2:@RequestPart接

SpringBoot整合Zuul全过程

《SpringBoot整合Zuul全过程》Zuul网关是微服务架构中的重要组件,具备统一入口、鉴权校验、动态路由等功能,它通过配置文件进行灵活的路由和过滤器设置,支持Hystrix进行容错处理,还提供... 目录Zuul网关的作用Zuul网关的应用1、网关访问方式2、网关依赖注入3、网关启动器4、网关全局变

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

SpringBoot的全局异常拦截实践过程

《SpringBoot的全局异常拦截实践过程》SpringBoot中使用@ControllerAdvice和@ExceptionHandler实现全局异常拦截,@RestControllerAdvic... 目录@RestControllerAdvice@ResponseStatus(...)@Except

Springboot配置文件相关语法及读取方式详解

《Springboot配置文件相关语法及读取方式详解》本文主要介绍了SpringBoot中的两种配置文件形式,即.properties文件和.yml/.yaml文件,详细讲解了这两种文件的语法和读取方... 目录配置文件的形式语法1、key-value形式2、数组形式读取方式1、通过@value注解2、通过

Java 接口定义变量的示例代码

《Java接口定义变量的示例代码》文章介绍了Java接口中的变量和方法,接口中的变量必须是publicstaticfinal的,用于定义常量,而方法默认是publicabstract的,必须由实现类... 在 Java 中,接口是一种抽象类型,用于定义类必须实现的方法。接口可以包含常量和方法,但不能包含实例

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

浅析python如何去掉字符串中最后一个字符

《浅析python如何去掉字符串中最后一个字符》在Python中,字符串是不可变对象,因此无法直接修改原字符串,但可以通过生成新字符串的方式去掉最后一个字符,本文整理了三种高效方法,希望对大家有所帮助... 目录方法1:切片操作(最推荐)方法2:长度计算索引方法3:拼接剩余字符(不推荐,仅作演示)关键注意事