Итак, я решил создать алгоритм с линейным и бинарным поиском, в котором у вас есть 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
Как оптимизировать поисковик точек 2D-массива? ⇐ C#
Место общения программистов C#
-
Anonymous
1766971257
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}");
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79854973/how-do-i-optimize-my-2d-array-point-searcher[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия