蓝桥杯第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按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group