Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
aa152147
五子棋
提交
7a2bc3b2
五
五子棋
项目概览
aa152147
/
五子棋
与 Fork 源项目一致
Fork自
inscode / VueJS
通知
1
Star
43
Fork
23
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
五
五子棋
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
7a2bc3b2
编写于
7月 04, 2023
作者:
6
63db3122f0950a2aef64df95
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Tue Jul 4 03:10:00 UTC 2023 inscode
上级
892df0fd
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
12 addition
and
10 deletion
+12
-10
src/App.vue
src/App.vue
+2
-2
src/utils/index.js
src/utils/index.js
+6
-8
vite.config.js
vite.config.js
+4
-0
未找到文件。
src/App.vue
浏览文件 @
7a2bc3b2
...
...
@@ -9,7 +9,7 @@ const win_size = ref(5)
const
lattices
=
ref
([])
// 下起记录
const
records
=
ref
([])
//
5 连珠
的下标
//
赢棋
的下标
let
isWin
=
[]
const
records_obj
=
computed
(()
=>
{
return
records
.
value
.
reduce
((
r
,
{
location
,
type
})
=>
{
...
...
@@ -60,7 +60,7 @@ async function playChess(item, row, col) {
return
}
// 机器人下棋
const
[
y
,
x
]
=
robotPlay
(
lattices
.
value
,
is_white
,
win_size
.
value
)
const
[
y
,
x
]
=
robotPlay
(
lattices
.
value
,
win_size
.
value
)
setPiece
([
y
,
x
],
is_white
)
const
testRobo
=
checkWin
({
row
:
y
,
col
:
x
,
board
:
lattices
.
value
,
player
:
is_white
,
win_size
:
win_size
.
value
})
...
...
src/utils/index.js
浏览文件 @
7a2bc3b2
...
...
@@ -62,11 +62,10 @@ export function checkWin({ row, col, board, player, win_size }) {
/**
* 机器人下棋位置
* @param {(is_empty|is_white|is_black)[][]} board 棋盘
* @param {is_white} robot 机器人
* @param {number} win_size 赢棋的棋子颗数
* @returns {number[]}
*/
export
function
robotPlay
(
board
,
robot
,
win_size
)
{
export
function
robotPlay
(
board
,
win_size
)
{
let
maxScorePos
=
[];
let
maxScore
=
-
1
;
// 空位
...
...
@@ -112,7 +111,7 @@ export function robotPlay(board, robot, win_size) {
* 积分最小为 4 * (10**0) = 4
*
* 边界判断
* 如果在棋盘边缘,需要判断连子最多有几颗,小于
5
颗,可以直接放弃当前位置
* 如果在棋盘边缘,需要判断连子最多有几颗,小于
win_size
颗,可以直接放弃当前位置
*/
/**
...
...
@@ -128,11 +127,10 @@ function getBoundary(size, num) {
/**
* 获取一个一个方向上的棋子数
* @param {*} board
* @param {*} row
* @param {*} col
* @param {*} param3
* @param {*} piece_type
* @param {number} row 行 y
* @param {number} col 列 x
* @param {(is_empty|is_white|is_black)[]} board 棋盘
* @param {number} win_size 需要几个棋子才赢
* @returns
*/
function
getDirectionScore
(
board
,
row
,
col
,
[
y
,
x
],
win_size
)
{
...
...
vite.config.js
浏览文件 @
7a2bc3b2
...
...
@@ -7,6 +7,10 @@ export default defineConfig({
host
:
true
},
plugins
:
[
vue
()],
server
:
{
https
:
true
,
host
:
true
,
},
define
:
{
'
process.env
'
:
{
INSCODE_API_KEY
:
process
.
env
.
INSCODE_API_KEY
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录