溫馨提示×

在C#中如何自定義Vector的排序規(guī)則

c#
小樊
87
2024-09-04 16:26:43
欄目: 編程語言

在C#中,你可以使用List<T>和自定義的比較器來實現(xiàn)自定義的Vector排序規(guī)則

using System;
using System.Collections.Generic;

class Program
{
    static void Main(string[] args)
    {
        List<Vector> vectors = new List<Vector>
        {
            new Vector(1, 2),
            new Vector(3, 4),
            new Vector(-1, -2)
        };

        vectors.Sort(new VectorComparer());

        foreach (var vector in vectors)
        {
            Console.WriteLine($"({vector.X}, {vector.Y})");
        }
    }
}

public class Vector
{
    public int X { get; set; }
    public int Y { get; set; }

    public Vector(int x, int y)
    {
        X = x;
        Y = y;
    }
}

public class VectorComparer : IComparer<Vector>
{
    public int Compare(Vector v1, Vector v2)
    {
        // 自定義排序規(guī)則,例如按照曼哈頓距離排序
        int distance1 = Math.Abs(v1.X) + Math.Abs(v1.Y);
        int distance2 = Math.Abs(v2.X) + Math.Abs(v2.Y);

        return distance1.CompareTo(distance2);
    }
}

在這個示例中,我們創(chuàng)建了一個名為Vector的類,并實現(xiàn)了一個名為VectorComparer的自定義比較器。VectorComparer實現(xiàn)了IComparer<Vector>接口,并重寫了Compare方法,該方法定義了排序規(guī)則。在這個例子中,我們按照曼哈頓距離對向量進行排序。

然后,我們創(chuàng)建了一個List<Vector>,并使用Sort方法對其進行排序。Sort方法接受一個IComparer<T>參數(shù),所以我們可以傳入自定義的比較器VectorComparer。最后,我們遍歷并打印排序后的向量列表。

0