首页 > 其他分享 >设计模式 - 策略模式

设计模式 - 策略模式

时间:2025-01-03 16:27:04浏览次数:1  
标签:Sort 策略 int list 模式 算法 设计模式 public

概述

策略模式(Strategy Pattern)是一种行为型设计模式,它定义了一系列算法,并将每个算法封装起来,使它们可以互相替换。策略模式使得算法可以独立于使用它的客户端而变化。通过使用策略模式,可以在运行时选择不同的算法,从而提高系统的灵活性和可维护性。

结构

策略模式包含以下几个角色:

  1. 策略(Strategy):定义所有支持的算法的公共接口。
  2. 具体策略(ConcreteStrategy):实现策略接口的具体算法。
  3. 上下文(Context):维护一个策略对象的引用,并在需要时调用策略对象的方法。

示例代码

假设我们有一个应用程序需要对一组数字进行排序,可以选择不同的排序算法(如冒泡排序和快速排序)。
代码地址

策略接口

public interface ISortStrategy
{
    void Sort(List<int> list);
}

具体策略

public class BubbleSortStrategy : ISortStrategy
{
    public void Sort(List<int> list)
    {
        Console.WriteLine("Using Bubble Sort");
        for (int i = 0; i < list.Count - 1; i++)
        {
            for (int j = 0; j < list.Count - i - 1; j++)
            {
                if (list[j] > list[j + 1])
                {
                    (list[j], list[j + 1]) = (list[j + 1], list[j]);
                }
            }
        }
    }
}

public class QuickSortStrategy : ISortStrategy
{
    public void Sort(List<int> list)
    {
        Console.WriteLine("Using Quick Sort");
        QuickSort(list, 0, list.Count - 1);
    }

    private static void QuickSort(IList<int> list, int left, int right)
    {
        while (true)
        {
            if (left >= right)
            { 
                return;
            }

            int pivot = Partition(list, left, right);

            QuickSort(list, left, pivot - 1);

            left = pivot + 1;
        }
    }

    private static int Partition(IList<int> list, int left, int right)
    {
        int pivot = list[right];
        int i = left - 1;

        for (int j = left; j < right; j++)
        {
            if (list[j] >= pivot)
            {
                continue;
            }

            i++;

            (list[i], list[j]) = (list[j], list[i]);
        }

        (list[i + 1], list[right]) = (list[right], list[i + 1]);

        return i + 1;
    }
}

上下文

public class SortContext
{
    private ISortStrategy _sortStrategy;

    public void SetSortStrategy(ISortStrategy sortStrategy)
    {
        _sortStrategy = sortStrategy;
    }

    public void Sort(List<int> list)
    {
        _sortStrategy.Sort(list);
    }
}

客户端代码

class Program
{
    static void Main(string[] args)
    {
        List<int> list = new List<int> { 5, 2, 9, 1, 5, 6 };

        SortContext context = new SortContext();

        context.SetSortStrategy(new BubbleSortStrategy());
        context.Sort(list);
        Console.WriteLine(string.Join(", ", list));

        list = new List<int> { 5, 2, 9, 1, 5, 6 };

        context.SetSortStrategy(new QuickSortStrategy());
        context.Sort(list);
        Console.WriteLine(string.Join(", ", list));
    }
}

应用场景

策略模式适用于以下场景:

  1. 需要使用多种算法:当一个系统需要在多种算法中选择一种时,可以使用策略模式。
  2. 算法独立变化:当算法的实现需要独立于使用它的客户端变化时,可以使用策略模式。
  3. 消除条件语句:当一个系统中包含大量的条件语句来选择合适的算法时,可以使用策略模式将这些条件语句替换为算法的封装。

优缺点

优点

  • 算法可以独立变化:策略模式使得算法可以独立于使用它的客户端变化,提高了系统的灵活性和可维护性。
  • 消除条件语句:策略模式通过将算法封装到独立的策略类中,消除了系统中的条件语句。

缺点

  • 增加类的数量:策略模式引入了大量的策略类,可能会增加系统的复杂性。
  • 客户端必须了解不同的策略:策略模式要求客户端了解不同的策略类,并自行选择合适的策略。

标签:Sort,策略,int,list,模式,算法,设计模式,public
From: https://www.cnblogs.com/Tangtang1997/p/18650336

相关文章

  • 设计模式 - 状态模式
    概述状态模式(StatePattern)是一种行为型设计模式,它允许对象在内部状态改变时改变其行为。状态模式通过将状态相关的行为封装到独立的状态类中,使得对象的行为可以随着状态的改变而改变。状态模式使得状态转换变得更加明确和可控,提高了系统的灵活性和可维护性。结构状态模式包含......
  • 设计模式 - 观察者模式
    概述观察者模式(ObserverPattern)是一种行为型设计模式,它定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象。当主题对象的状态发生变化时,所有依赖于它的观察者对象都会得到通知并自动更新。观察者模式使得对象之间的耦合度降低,提高了系统的灵活性和可维护性。......
  • 设计模式 - 访问者模式
    概述访问者模式(VisitorPattern)是一种行为型设计模式,它通过为对象结构中的每个元素添加一个访问操作,使得可以在不改变元素类的前提下定义作用于这些元素的新操作。访问者模式将操作的逻辑从对象结构中分离出来,使得新的操作可以很容易地添加到对象结构中。结构访问者模式包含以......
  • 设计模式 - 模板方法模式
    概述模板方法模式(TemplateMethodPattern)是一种行为型设计模式,它定义了一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法模式使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤。通过使用模板方法模式,可以提高代码的复用性和灵活性。结构模板方法模式......
  • 设计模式合集
    目录引言设计模式的分类创建型模式结构型模式行为型模式引言在软件开发的世界中,设计模式是一种经过验证的解决方案,用于解决常见的设计问题。它们不仅提高了代码的可维护性和可扩展性,还使开发人员能够更高效地进行开发工作。设计模式提供了一种标准化的方法来解决软件设计中的重......
  • 设计模式 - 建造者模式
    概述建造者模式(BuilderPattern)是一种创建型设计模式,它将一个复杂对象的构建过程与其表示分离,使得同样的构建过程可以创建不同的表示。通过使用建造者模式,可以一步一步地构建一个复杂的对象,并且可以根据需要改变对象的内部表示。结构建造者模式包含以下几个角色:产品(Product):表......
  • 设计模式 - 单例模式
    概述单例模式(SingletonPattern)是一种创建型设计模式,它确保一个类只有一个实例,并提供一个全局访问点来访问该实例。这种模式在很多场景中都很常见,例如数据库连接池、日志记录器、配置管理器等,通过确保一个类只有一个实例,提高了代码的灵活性和可维护性。结构单例模式通常包含以......
  • 设计模式 - 适配器模式
    概述适配器模式(AdapterPattern)是一种结构型设计模式,它将一个类的接口转换成客户希望的另一个接口,使得原本由于接口不兼容而不能一起工作的类可以一起工作。适配器模式通过引入一个适配器类来解决接口不兼容的问题,从而提高了代码的复用性和灵活性。结构适配器模式包含以下几个......
  • 设计模式 - 原型模式
    概述原型模式(PrototypePattern)是一种创建型设计模式,它通过复制现有的实例来创建新的对象,而不是通过实例化类。原型模式允许一个对象在创建新的对象时,通过复制自身来实现。这种模式特别适用于创建复杂对象的场景,因为它可以避免重复初始化对象的开销。结构原型模式包含以下几个......
  • 设计模式 - 装饰模式
    概述装饰模式(DecoratorPattern)是一种结构型设计模式,它允许向一个现有的对象添加新的功能,同时又不改变其结构。装饰模式通过创建一个装饰类来包装原始类,从而在保持类方法签名完整的前提下,提供了额外的功能。装饰模式比生成子类更灵活,能够动态地扩展对象的功能。结构装饰模式包......