试图实际上做一个井字游戏.所以如果有更好的方式我也想知道!
所以我有一个网格[0,8],用户的位置存储在一个数组中.大.
接下来我想看看列是否匹配.所以我们假设第一行是(0,1,2).
我的问题是,如果用户有一个像数组(1,5,6,0,2)的数组,所以他赢了.我怎样才能有效地匹配它?
我在考虑做这样的事情,但效率不高:
$user= array(1,5,6,0,2);
in_array(0,$user) && in_array(1,$user) && in_array(2,$user)
我也考虑过切换案例,但仍然面临如何一次找到多个值的问题.
最佳答案 我同意,只需少量可能的组合就可以获得,解决方案可以保持非常简单.我会用array_diff来做.
function has_won($user) {
// returns false if the user has not won, otherwise
// returns the first winning combination found.
$wins = [[0,1,2],[3,4,5],[6,7,8],[0,3,6],[1,4,7],[2,5,8],[0,4,8],[2,4,6]];
foreach ($wins as $win) {
if (!array_diff($win, $user)) return $win;
// array_diff returns the values in the first argument
// not present in any subsequent arguments. So if its
// result is empty, the user has winning combination.
}
return false;
}