- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
<分区>
我正在使用 C#.NET 构建战舰游戏。它应该使用相当简单的评分机制。没有船沉没,如果玩家或计算机获得 17 次命中,则他们获胜。如果你命中,你可以再转一圈。 AI随机攻击直到命中,此时它会在每个方向攻击一个瓷砖直到找到趋势,然后继续直线攻击直到找到死胡同(未被占用的空间或边缘)板。如果在计算机攻击的相反方向上有未被击中的空间,它将攻击这些空间。它不会瞄准它已经击中的空间或遵循已经遵循的模式。
到目前为止,这是我的 AI。
int shipCounter = 0, trend = 0;
static Random rnd = new Random();
bool gameOver = false, playerTurn = false;
int[] score = { 0, 0 };
struct gameData
{
public bool occupied, hit, marked;
}
gameData[,,] data;
public void computerMove()
{
Point target = seekTarget();
try
{
if (data[1, target.X, target.Y].hit)
computerMove();
else
{
data[1, target.X, target.Y].hit = true;
if (data[1, target.X, target.Y].occupied)
{
attacking = true;
score[0]++;
computerMove();
}
}
playerTurn = true;
}
catch (IndexOutOfRangeException)
{ computerMove(); }
}
public Point seekTarget()
{
Point origin = new Point(-1, -1);
//find a point that's been hit.
int x = 0, y = 0;
while (x < gridSize && y < gridSize)
{
if (data[1, x, y].hit && data[1, x, y].occupied && !data[1, x, y].marked)
{
origin = new Point(x, y);
break;
}
x++;
if (x == gridSize && y != gridSize)
{
x = 0;
y++;
}
}
return findTargets(origin);
}
public Point findTargets(Point origin)
{
Point[] lim = { origin, origin, origin, origin };
Point[] possibleTargets = { origin, origin, origin, origin };
//Find the edges.
while (lim[0].X >= -1 && ((!data[1, lim[0].X, lim[0].Y].hit && !data[1, lim[0].X, lim[0].Y].occupied) || (data[1, lim[0].X, lim[0].Y].hit && data[1, lim[0].X, lim[0].Y].occupied)))
{
lim[0].X--;
if (lim[0].X == -1)
break;
}
while (lim[1].Y >= -1 && ((!data[1, lim[0].X, lim[0].Y].hit && !data[1, lim[0].X, lim[0].Y].occupied) || (data[1, lim[0].X, lim[0].Y].hit && data[1, lim[0].X, lim[0].Y].occupied)))
{
lim[1].Y--;
if (lim[1].Y == -1)
break;
}
while (lim[2].X <= gridSize && ((!data[1, lim[0].X, lim[0].Y].hit && !data[1, lim[0].X, lim[0].Y].occupied) || (data[1, lim[0].X, lim[0].Y].hit && data[1, lim[0].X, lim[0].Y].occupied)))
{
lim[2].X++;
if (lim[2].X == gridSize)
break;
}
while (lim[3].Y <= gridSize && ((!data[1, lim[0].X, lim[0].Y].hit && !data[1, lim[0].X, lim[0].Y].occupied) || (data[1, lim[0].X, lim[0].Y].hit && data[1, lim[0].X, lim[0].Y].occupied)))
{
lim[3].Y++;
if (lim[3].Y == gridSize)
break;
}
//Cell targeting AI
}
return new Point(rnd.Next(10), rnd.Next(10));
}
由于我无法弄清楚出了什么问题,它变得非常困惑。如果我引用 findTargets
函数并让计算机随机攻击,它就可以正常工作。计算机和玩家轮流交易,计算机命中记录。
但是,启用findTargets
后,玩家可以进行一次攻击,而计算机永远不会轮到它。然后它不会恢复到玩家回合,即使玩家的攻击十字准线仍然可见。如果有人可以提供帮助,将不胜感激。抱歉没有包含 Paint
或 mouseDown
方法,它们超出了字符限制。
没有 findTargets
的 UI(播放器和计算机交换)。
带有 findTargets
的 UI(计算机无法轮流,玩家只能轮流一次)。
在此先感谢您的帮助。
编辑: 我已经确定了问题所在,它似乎无法跳出 findTargets
中的 while 循环。即使我通过在 origin
为 (-1, -1)
时停止循环来解决问题,它也会在第一次命中时陷入循环。
编辑 2: 它会触发第一个循环,然后无限循环。出于某种原因,它根本不会增加 lim[0].X
。当我在循环中插入一个消息框以显示一些数据时,它显示两次然后不再出现,即使它仍在循环中。有谁知道这是为什么吗?
所以,我必须在 10x10 的板上制作一个用户对计算机的 Battleship 游戏来上编程课。我必须让计算机随机放置五艘大小为 5、4、3、3 和 2 的船。 我所做的是,我生成了 0 到 9 之间
我正在学习创建一个java游戏,对java来说还是个新手。现在我想创建一个战舰游戏。但现在我被困在这里了。现在,当我随机放置船作为电脑板时,有时它会与之前的船重叠,因此游戏变得不平衡。其次,在我收到玩
我正在制作战舰游戏,一切正常。但是由于我加入了一个回合系统,游戏无法正常运行。游戏有两个棋盘(一个是隐藏的,另一个是“公开的”,对手可以看到(所以没有船只)。隐藏的有效,但公众每回合都会重置,所以你看
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎是题外话,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或include a min
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
我正在制作一款战舰游戏。我创建了一个 Ship 类来为船只提供位置。 创建类后,我必须创建所有实例,我想知道是否有一种方法可以自动化它。 大部分程序都是无关紧要的,但我将其保留,以防万一它可能会影响它
我的编译器告诉我有错误,但我已经给我的导师发了电子邮件,他说我的代码非常好。 错误是错误: 1 error C4716: 'ShipPlacement' : must return a value,
我是一个想学习Java的菜鸟。我正在阅读《Head First Java》一书,并且非常喜欢它。我在学习使用 ArrayList<> 时遇到了一个问题而不是常规的array[] 。我在尝试分配 int
我是一名优秀的程序员,十分优秀!