Как оптимизировать поисковик точек 2D-массива?C#

Место общения программистов C#
Ответить
Anonymous
 Как оптимизировать поисковик точек 2D-массива?

Сообщение Anonymous »

Итак, я решил создать алгоритм с линейным и бинарным поиском, в котором у вас есть 2D-массив, такой как Array [,] = {{5,2}, {0,3}, {1,2}, {3,2}}, и он находит определенный подмассив, например, {5,2}. Я придумал с помощью Copilot просто сравнить точки, чтобы упорядочить массив, а затем просмотреть его, как двоичный поиск, чтобы найти конкретный индекс. Он написан на C#, и у меня такое ощущение, что в будущем проекте он будет слишком медленным. Обратите внимание, что у меня нет большого опыта в этом языке или в алгоритмах, и я могу найти много слов или концепций, которые трудно понять.
Вот код:
using System;

public class HelloWorld
{
static int CompareVectors(int[] A, int[] B)
{
if(A[0] > B[0]) return 1;
if(A[0] < B[0]) return -1;
if(A[1] > B[1]) return 1;
if(A[1] < B[1]) return -1;
return 0;
}
static int DoubleBinarySearch(int[,] arr, int[] target)
{
int low = 0;
int high = arr.GetLength(0);
int mid = 0;
int cmp = 0;
while (high >= low)
{
mid = (high + low) / 2;
int[] point1 = {arr[mid, 0],arr[mid, 1]};
cmp = CompareVectors(point1, target);
// equal
if (cmp == 0)
{
return mid;
}
// check right side (less than)
if (cmp < 0)
{
low = mid + 1;
}
//check left side (greater than)
if (cmp > 0)
{
high = mid - 1;
}
}
return -1;
}
public static void Main()
{
int[,] points = {{0,5},{0,4},{0,2},{0,3},{1,2},{3,2},{2,3}};
int[] target = {1,2};
int y = DoubleBinarySearch(points, target);
Console.WriteLine($"Point is found at index {y}");

}
}



Подробнее здесь: https://stackoverflow.com/questions/798 ... t-searcher
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»