问题描述:对于Point[] points坐标数组(Point是坐标点,包含X与Y),请计算两两坐标点之间的距离。
思路:既然是算距离,没有别的要求,只需要最简单的曼哈顿距离就行。
测试数据:
Random random = new Random();
int n = 3000;
Point[] points = new Point[n];
for (int i = 0; i < n; i++)
{
points[i] = new Point(random.Next(10), random.Next(10));
}
方法一:采用普通遍历法
Stopwatch sw = Stopwatch.StartNew();
int m = (n * n - n) / 2;
List<int> list2 = new List<int>(m);
for (int i = 0; i < n; i++)
{
Point p= points[i];
for (int j = i + 1; j < n; j++)
{
Point p2 = points[j];
int dif = Math.Abs(p.X - p2.X) + Math.Abs(p.Y - p2.Y);
list2.Add(dif);
}
}
sw.Stop();
Console.WriteLine($"普通耗时:{sw.ElapsedMilliseconds}ms");
方法二:采用SIMD加速
public static int[] CalculateDistance(Point[] points)
{
int n = points.Length;
int m = (n * n - n) >&g

最低0.47元/天 解锁文章
1339

被折叠的 条评论
为什么被折叠?



