gpt4 book ai didi

java - 在较大的二维数组中查找较小的二维数组

转载 作者:搜寻专家 更新时间:2023-11-01 03:23:51 25 4
gpt4 key购买 nike

代码的用途:无需人工干预即可自动识别屏幕上的按钮/获取其坐标。 (代码应该在更大的二维数组中找到一个二维数组)。

我是如何尝试解决它的:我将每个 RGB 像素值存储在二维数组中(a[][] 也称为大阵)。我将按钮像素/较小的 2Darray 存储在 optionArrayButton[][] 中。然后对这些步骤进行编码:(阅读本文时请查看下面的数组)。

  1. 获取 SmallerArray[0][0] = firstSmallerArray 的数字
  2. 通过从 [0][0][0][end] 然后 检查 FirstSmallerArray 数字的更大数组[1][0][1][end] 等等。
  3. 如果未找到 firstSmallerArray 编号,则返回 -1not Found
  4. 否则获取它在更大数组中的位置。
  5. 获取 Smaller Array 的高度 (smallerArray.length) 和宽度 (smallerArray[0].length)。
  6. 使用 firstSmallerArray 数字、smallerArray.lengthsmallerArray[0].length 存储在临时数组中。
  7. 检查 temp == smallerArray 并获取坐标。

我需要什么帮助: 出于某种原因,即使较小的数组在较大的数组内,它也说找不到按钮(foundButton 返回 false)。我花了两天时间,但找不到问题所在。

因为我使用的数组有超过 200 万个 RGB 值,所以我将以这些数组为例。更大的数组:

[3 3 1 0 9]
[4 1 5 4 5]
[7 5 6 2 8]
[8 2 7 3 5]
[1 8 7 6 4]

较小的数组:

[5 6 2]
[2 7 3]
[8 7 6]

我在编码方面有点菜鸟,所以我可能不会理解 java/编码术语。再次感谢任何可以提供帮助的人。

DataStorage DataStorageObject = new DataStorage();
int[][] optionArrayButton = DataStorageObject.optionArrayButton();

int firstSmallerArrayNumber = optionArrayButton[0][0]; //Step 1
int heightOfSmallerArray = optionArrayButton.length; //Step 5
int widthOfSmallerArray = optionArrayButton[0].length; //Step 5

boolean foundButton = false;

//a[][] has the screens rgb values
for(int yaxisCounter = 0; yaxisCounter < 300; yaxisCounter++) //Step 2
{
for(int xaxisCounter = 0; xaxisCounter < 300; xaxisCounter++) //Step 2
{
if(a[yaxisCounter][xaxisCounter] == firstSmallerArrayNumber) //Step 4
{
int[][] tempArray = new int[heightOfSmallerArray][widthOfSmallerArray]; //Step 6
// System.out.println(" " + yaxisCounter + ", " + xaxisCounter);
for(int ycounterForTemp = 0; ycounterForTemp < heightOfSmallerArray; ycounterForTemp++) //Step 6
{
for(int xcounterForTemp = 0; xcounterForTemp < widthOfSmallerArray; xcounterForTemp++) //Step 6
{
tempArray[ycounterForTemp][xcounterForTemp] = a[yaxisCounter][xaxisCounter]; //Step 6
// System.out.println("Storing in temp");
}
}

foundButton = isArrayEqual(tempArray, optionArrayButton); //Step 7
// System.out.println("Button found is a " + foundButton + " statement");

if(foundButton)
{
basePointy = yaxisCounter;
basePointx = xaxisCounter;

// System.out.println("Base Point y is: " + basePointy);
// System.out.println("Base Point x is: " + basePointx);

}

//If there are any problems this is where it would happen
else
{
// System.out.println("Button Found is a : " + "false" + " statement");
// System.out.println("In the nested Else");
continue;
}


}
else
{
// System.out.println("In the else");
continue;
}
}
}

// System.out.println("Button Found is a : " + foundButton + " statement");

最佳答案

使用这种方法:

int[][] matrix = ...;
int[][] submatrix = ...;

loopX: for (int x = 0; x < matrix.length - submatrix.length + 1; ++x)
loopY: for (int y = 0; y < matrix[x].length - submatrix[0].length + 1; ++y)
{
for (int xx = 0; xx < submatrix.length; ++xx)
for (int yy = 0; yy < submatrix[0].length; ++yy)
{
if (matrix[x + xx][y + yy] != submatrix[xx][yy])
{
continue loopY;
}
}

// Found the submatrix!
System.out.println("Found at: " + x + " " + y);
break loopX;
}
System.out.println("Done");

您的魔数(Magic Number) 300 可疑。也许您的按钮距离左侧或顶部超过 300 像素?还要确保使用无损图像。只有 1 位错误,这失败了。

关于java - 在较大的二维数组中查找较小的二维数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20828033/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com