大厂笔试真题讲解—京东23—夹吃棋

2024-06-21 13:04

本文主要是介绍大厂笔试真题讲解—京东23—夹吃棋,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本题主要讲解夹吃棋要点和细节,根据步骤一步步思考易于理解

提供c++的核心代码以及acm模式代码,末尾

题目描述

在一个 3 * 3 的棋盘上,小红和小紫正在玩“夹吃棋”。 所谓“夹吃棋”,即如果存在一个白子,它的两侧 (横向或者纵向)相邻都是黑子,则这个棋子将被“夹吃”,对于黑棋亦然。 

如果一个棋盘的局面没有一方被夹吃,或者黑白双方都被对面夹吃,则认为是平局。如果只有一方夹吃了另一方,则认为夹吃方赢,被夹吃方输。 

小红执黑棋,小紫执白棋,现在给定一个局面,请你判断当前棋局是谁获胜。

输入描述

第一行输入一个正整数 t (1 <= t <= 10000),代表询问的次数。 

接下来每组询问输入三行,,每行是一个长度为3的字符串,字符串仅由'o','.','*'组成。

其中 o 代表白棋,* 代表黑棋,. 代表未放置棋子。

输出描述

小红获胜输出“kou”,小紫获胜输出“yukan”,平局输出“draw”。

输入示例
3
...
o*o
...
o**
ooo
..*
o*o
*o*
o*o
输出示例
yukan
kou
draw

 具体要点(针对笔试的ACM模式进行讲解): 

1. 首先拿到这道题时,先把输入输出做好(许多小伙伴做leetcode比较多,对acm模式不熟练,核心代码写清楚了,但是不满足acm模式,就太可惜了所以我们最好上来先把输入输出写对调通)

首先明确我们的输入

  • 一个正整数 t (1 <= t <= 10000),代表询问的次数。 
  • 每组询问输入三行,每行是一个长度为3的字符串,字符串仅由'o','.','*'组成,代表我们的棋盘

其次考虑我们的输出

  • 输出是一个字符串,小红获胜输出“kou”,小紫获胜输出“yukan”,平局输出“draw”。

所以我们先写好我们的输入输出 

int main() {Solution sol;int t;//定义询问次数cin >> t;vector<vector<char>> arr(3, vector<char>(3, ' '));//定义棋盘for (int i = 0;i < t;i++) { //询问次数for (int j = 0;j < 3;j++) {  //每次输入三行string s;for (int k = 0;k < 3;k++) {cin >> arr[j][k];}}cout << sol.fun(arr) << endl;//我们的arr中每次只保留一个3*3的棋盘,注意这行代码的位置}
}

 2. 然后我们分析一下题意以及核心问题

        要判断谁赢的条件是:是否存在夹吃,即黑棋两侧是白棋,白棋两侧是黑棋。

(这里需要注意!只要有一个夹吃存在即可,若黑白棋都有夹吃,就平局,不需要比较谁夹吃的数量多,题主第一次做时,就理解错了

        判断条件出来了,然后我们考虑怎么遍历所有的情况,因为判断的是两侧与中间的情况,两侧包括上下两侧,左右两侧。同时拥有两侧的“中间”也只有3*3棋盘的十字位置(5个元素)

        到这里我们也就清晰了我们要处理或者遍历的是:5个位置的元素,判断他们是不是夹吃,被谁夹吃。遍历顺序就是按行,列进行遍历

        bool white = false, black = false;//横向判断for (int i = 0;i < 3;i++) {if (arr[i][1] != '.' && arr[i][0] == arr[i][2] && arr[i][0] != '.') {  //限定了该位置有棋子,且两侧有棋子并且相同if (arr[i][1] == 'o'&&arr[i][0]!='o')black=true;  // 该位置为o,且两侧不为o,则夹吃else if (arr[i][1] == '*'&&arr[i][0]!='*')white=true;}}//纵向判断for (int j = 0;j < 3;j++) {if (arr[1][j] != '.' && arr[0][j] == arr[2][j] && arr[0][j] != '.') {if (arr[1][j] == 'o'&&arr[0][j]!='o')black=true;else if (arr[1][j] == '*'&&arr[0][j]!='*')white=true;}}

3. 最后我们根据黑白棋子夹吃情况,进行输出

        黑赢:黑存在夹吃,白不存在

        白赢:白存在夹吃,黑不存在

        平局:黑白都不存在,或黑白都存在


细节问题:

  • 本题主要考虑的细节就是判定夹吃的情况:

        中心位置有棋子 —> 两侧位置有棋子且相同——>中心位置和两侧棋子不一样

  • 再简单考虑一下是否需要long long :1 <= t <= 10000,没有超过int=2147483647,所以不需要

这道题其实不难,第一眼看上去是个二维问题以为会很难,其实想清楚后很简单

希望我的讲解能对你有点帮助,加油

完整代码如下:

#include<vector>
#include<bits/stdc++.h>
using namespace std;class Solution {
public:string fun(vector<vector<char>>& arr) {bool white = false, black = false;//横向判断for (int i = 0;i < 3;i++) {if (arr[i][1] != '.' && arr[i][0] == arr[i][2] && arr[i][0] != '.') {  //限定了该位置有棋子,且两侧有棋子并且相同if (arr[i][1] == 'o'&&arr[i][0]!='o')black=true;  // 该位置为o,且两侧不为o,则夹吃else if (arr[i][1] == '*'&&arr[i][0]!='*')white=true;}}//纵向判断for (int j = 0;j < 3;j++) {if (arr[1][j] != '.' && arr[0][j] == arr[2][j] && arr[0][j] != '.') {if (arr[1][j] == 'o'&&arr[0][j]!='o')black=true;else if (arr[1][j] == '*'&&arr[0][j]!='*')white=true;}}if (black == true && white == false)return "kou";else if (black == false && white == true)return "yukan";else return "draw";}
};int main() {Solution sol;int t;//定义询问次数cin >> t;vector<vector<char>> arr(3, vector<char>(3, ' '));//定义棋盘for (int i = 0;i < t;i++) { //询问次数for (int j = 0;j < 3;j++) {  //每次输入三行string s;for (int k = 0;k < 3;k++) {cin >> arr[j][k];}}cout << sol.fun(arr) << endl;//我们的arr中每次只保留一个3*3的棋盘,注意这行代码的位置}
}

这篇关于大厂笔试真题讲解—京东23—夹吃棋的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

【秋招笔试】9.07米哈游秋招改编题-三语言题解

🍭 大家好这里是 春秋招笔试突围,一起备战大厂笔试 💻 ACM金牌团队🏅️ | 多次AK大厂笔试 | 大厂实习经历 ✨ 本系列打算持续跟新 春秋招笔试题 👏 感谢大家的订阅➕ 和 喜欢💗 和 手里的小花花🌸 ✨ 笔试合集传送们 -> 🧷春秋招笔试合集 🍒 本专栏已收集 100+ 套笔试题,笔试真题 会在第一时间跟新 🍄 题面描述等均已改编,如果和你笔试题看到的题面描述

京东物流查询|开发者调用API接口实现

快递聚合查询的优势 1、高效整合多种快递信息。2、实时动态更新。3、自动化管理流程。 聚合国内外1500家快递公司的物流信息查询服务,使用API接口查询京东物流的便捷步骤,首先选择专业的数据平台的快递API接口:物流快递查询API接口-单号查询API - 探数数据 以下示例是参考的示例代码: import requestsurl = "http://api.tanshuapi.com/a

华为OD机试真题-学生方阵-2024年OD统一考试(E卷)

题目描述 学校组织活动,将学生排成一个矩形方阵。 请在矩形方阵中找到最大的位置相连的男生数量。这个相连位置在一个直线上,方向可以是水平的,垂直的,成对角线的或者呈反对角线的。 注:学生个数不会超过10000 输入描述 输入的第一行为矩阵的行数和列数, 接下来的 n行为矩阵元素,元素间用""分隔。 输出描述 输出一个整数,表示矩阵中最长的位

ispunct函数讲解 <ctype.h>头文件函数

目录 1.头文件函数 2.ispunct函数使用  小心!VS2022不可直接接触,否则..!没有这个必要,方源一把抓住VS2022,顷刻 炼化! 1.头文件函数 以上函数都需要包括头文件<ctype.h> ,其中包括 ispunct 函数 #include<ctype.h> 2.ispunct函数使用 简述: ispunct函数一种判断字符是否为标点符号的函

深度学习速通系列:深度学习算法讲解

深度学习算法是一系列基于人工神经网络的算法,它们通过模拟人脑处理信息的方式来学习和解决复杂问题。这些算法在图像识别、语音识别、自然语言处理、游戏等领域取得了显著的成就。以下是一些流行的深度学习算法及其基本原理: 1. 前馈神经网络(Feedforward Neural Networks, FNN) 原理:FNN 是最基本的神经网络结构,它由输入层、隐藏层和输出层组成。信息从输入层流向隐藏层,最

2024年AMC10美国数学竞赛倒计时两个月:吃透1250道真题和知识点(持续)

根据通知,2024年AMC10美国数学竞赛的报名还有两周,正式比赛还有两个月就要开始了。计划参赛的孩子们要记好时间,认真备考,最后冲刺再提高成绩。 那么如何备考2024年AMC10美国数学竞赛呢?做真题,吃透真题和背后的知识点是备考AMC8、AMC10有效的方法之一。通过做真题,可以帮助孩子找到真实竞赛的感觉,而且更加贴近比赛的内容,可以通过真题查漏补缺,更有针对性的补齐知识的短板。

C#设计模式(1)——单例模式(讲解非常清楚)

一、引言 最近在学设计模式的一些内容,主要的参考书籍是《Head First 设计模式》,同时在学习过程中也查看了很多博客园中关于设计模式的一些文章的,在这里记录下我的一些学习笔记,一是为了帮助我更深入地理解设计模式,二同时可以给一些初学设计模式的朋友一些参考。首先我介绍的是设计模式中比较简单的一个模式——单例模式(因为这里只牵涉到一个类) 二、单例模式的介绍 说到单例模式,大家第一