1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-26 18:20:27 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/井字游戏 [tic-tac-toe-lcci].html
2022-03-29 12:43:11 +08:00

42 lines
1.9 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>设计一个算法,判断玩家是否赢了井字游戏。输入是一个 N x N 的数组棋盘,由字符&quot; &quot;&quot;X&quot;&quot;O&quot;组成,其中字符&quot; &quot;代表一个空位。</p>
<p>以下是井字游戏的规则:</p>
<ul>
<li>玩家轮流将字符放入空位(&quot; &quot;)中。</li>
<li>第一个玩家总是放字符&quot;O&quot;,且第二个玩家总是放字符&quot;X&quot;</li>
<li>&quot;X&quot;&quot;O&quot;只允许放置在空位中,不允许对已放有字符的位置进行填充。</li>
<li>当有N个相同且非空的字符填充任何行、列或对角线时游戏结束对应该字符的玩家获胜。</li>
<li>当所有位置非空时,也算为游戏结束。</li>
<li>如果游戏结束,玩家不允许再放置字符。</li>
</ul>
<p>如果游戏存在获胜者,就返回该游戏的获胜者使用的字符(&quot;X&quot;&quot;O&quot;);如果游戏以平局结束,则返回 &quot;Draw&quot;;如果仍会有行动(游戏未结束),则返回 &quot;Pending&quot;</p>
<p><strong>示例 1</strong></p>
<pre><strong>输入:</strong> board = [&quot;O X&quot;,&quot; XO&quot;,&quot;X O&quot;]
<strong>输出:</strong> &quot;X&quot;
</pre>
<p><strong>示例 2</strong></p>
<pre><strong>输入:</strong> board = [&quot;OOX&quot;,&quot;XXO&quot;,&quot;OXO&quot;]
<strong>输出:</strong> &quot;Draw&quot;
<strong>解释:</strong> 没有玩家获胜且不存在空位
</pre>
<p><strong>示例 3</strong></p>
<pre><strong>输入:</strong> board = [&quot;OOX&quot;,&quot;XXO&quot;,&quot;OX &quot;]
<strong>输出:</strong> &quot;Pending&quot;
<strong>解释:</strong> 没有玩家获胜且仍存在空位
</pre>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= board.length == board[i].length &lt;= 100</code></li>
<li>输入一定遵循井字棋规则</li>
</ul>