基本上我的第一个任务是将'0'的位置保存在整数中。真正简单的标准阵列。此代码循环遍历数组(大小:8),直到找到0,然后将其保存为位置。请参阅以下代码:
p.s:n是对其他地方保存的数组的引用。
int position = 0;
this.nodesExpanded++;
// Loop through the array to get the position of where '0' is
for (int i = 0; i < n.getPuzzle().length; i++){
if (n.getPuzzle()[i] == 0){
position = i;
break;
}
}
我的最终任务是使多维数组成为可能(大小:[3,3])。所以这就是我迄今为止所创造的内容:
for (int x = 0; x < 3; x++)
{
for (int y = 0; y < 3; y++)
{
if (n.getPuzzle()[x,y] == 0)
{
**position = ;**
break;
}
}//end y loop
}//end x loop
那么如何将位置的数组引用保存到值呢? 'position'将需要是int而不是int我猜...
如果您需要更多说明,请务必发表评论,提前抱歉。谢谢!
答案 0 :(得分:2)
您可以使用Tuple
来存储该位置。或者您可以创建自己的数据结构。
示例:最后,您可以看到如何访问元组项。
var positions = new List<Tuple<int, int>>();
for (int x = 0; x < 3; x++)
{
for (int y = 0; y < 3; y++)
{
if (n.getPuzzle()[x,y] == 0)
{
positions.Add(new Tuple<int, int>(x,y));
break;
}
}//end y loop
}//end x loop
if(positions.Any())
{
var xpos = positions[0].Item1;
var ypos = positions[0].Item2;
}
答案 1 :(得分:0)
我发现存储多维数组索引的一种自然方法是使用尺寸为维数的单维数组。
因此,如果您有object[,,] A
和索引int[] i
,则会使用表达式A[i[0],i[1],i[2]]
将其编入索引。
答案 2 :(得分:0)
它的工作方式与您的一维数组相同,但您需要保留两个位置值。我已经使用int
作为示例,但您可能希望使用自定义结构或Tuple(如AD.Net)所说。
int xpos = -1;
int ypos = -1;
for (int x = 0; x < 3; x++)
{
for (int y = 0; y < 3; y++)
{
if (n.getPuzzle()[x,y] == 0)
{
xpos = x;
ypos = y;
break;
}
}//end y loop
}//end x loop
if (!(xpos > -1 && ypos > -1)) ; // 0 was not found