迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 >

在 C# 中混排列表

作者:迹忆客 最近更新:2024/01/16 浏览次数:

在本教程中,我们将讨论在 C# 中对列表进行混排的方法。


在 C# 中使用 Linq 混排列表

语言集成查询或 Linq 提供了一种在 C# 中集成查询功能的方法。Linq 提供的功能类似于 C# 中的 SQL。我们可以使用 Linq 将列表随机化。以下代码示例向我们展示了如何在 C# 中使用 Linq 来整理列表。

using System;
using System.Collections.Generic;
using System.Linq;

namespace shuffle_list {
  class Program {
    static void Main(string[] args) {
      List<int> list1 = new List<int>() { 1, 2, 3, 4, 5 };

      var rnd = new Random();
      var randomized = list1.OrderBy(item => rnd.Next());

      foreach (var value in randomized) {
        Console.WriteLine(value);
      }
    }
  }
}

输出:

1
4
5
3
2

我们首先初始化列表 list1,然后使用 C# 中 Linq 的 random.next() 函数和 OrderBy() 函数对列表 list1 进行混洗。上面的方法还可以用于在 C# 中对对象列表进行随机组合。以下代码示例向我们展示了如何在 C# 中使用 Linq 来整理对象列表。

using System;
using System.Collections.Generic;
using System.Linq;

namespace shuffle_list {
  public class Person {
    string name;
    public Person(string name) {
      Name = name;
    }
    public string Name {
      get => name;
      set => name = value;
    }
  }
  class Program {
    static void Main(string[] args) {
      List<Person> list1 = new List<Person>();

      list1.Add(new Person("Person 1"));
      list1.Add(new Person("Person 2"));
      list1.Add(new Person("Person 3"));
      list1.Add(new Person("Person 4"));
      list1.Add(new Person("Person 5"));

      var rnd = new Random();
      var randomized = list1.OrderBy(item => rnd.Next());

      foreach (var value in randomized) {
        Console.WriteLine(value.Name);
      }
    }
  }
}

输出:

Person 5
Person 2
Person 1
Person 3
Person 4

我们使用 C# 中的 Linq 对 Person 类的对象列表进行了混排。


使用 C# 中的 Fisher-Yates Shuffle 算法混排列表

Fisher-Yates Shuffle 算法在 C# 中对有限数据结构进行混排。Fisher-Yates 混排算法在 C# 中提供了无偏混排。它将列表中的每个元素顺序存储到列表中的随机索引中。下面的编码示例向我们展示了如何使用 C# 中的 Fisher-Yates 混排算法来混排列表。

using System;
using System.Collections.Generic;
using System.Linq;

namespace shuffle_list {
  static class ExtensionsClass {
    private static Random rng = new Random();

    public static void Shuffle<T>(this IList<T> list) {
      int n = list.Count;
      while (n > 1) {
        n--;
        int k = rng.Next(n + 1);
        T value = list[k];
        list[k] = list[n];
        list[n] = value;
      }
    }
  }

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

      list1.Shuffle();

      foreach (var value in list1) {
        Console.WriteLine(value);
      }
    }
  }
}

输出:

5
1
4
3
2

我们使用 C# 中的 Fisher-Yates 混排算法对整数 list1 的列表进行了混排。我们创建了一种扩展方法,用于在 C# 中实现 Fisher-Yates 算法。要创建扩展方法,我们必须在另一个称为 ExtensionClassstatic 类中定义 Shuffle() 函数。如下面的代码所示,也可以使用相同的算法对对象列表进行混排。

using System;
using System.Collections.Generic;
using System.Linq;

namespace shuffle_list {

  public class Person {
    string name;
    public Person(string name) {
      Name = name;
    }
    public string Name {
      get => name;
      set => name = value;
    }
  }

  static class ExtensionsClass {
    private static Random rng = new Random();

    public static void Shuffle<T>(this IList<T> list) {
      int n = list.Count;
      while (n > 1) {
        n--;
        int k = rng.Next(n + 1);
        T value = list[k];
        list[k] = list[n];
        list[n] = value;
      }
    }
  }

  class Program {
    static void Main(string[] args) {
      List<Person> list1 = new List<Person>();

      list1.Add(new Person("Person 1"));
      list1.Add(new Person("Person 2"));
      list1.Add(new Person("Person 3"));
      list1.Add(new Person("Person 4"));
      list1.Add(new Person("Person 5"));

      list1.Shuffle();

      foreach (var value in list1) {
        Console.WriteLine(value.Name);
      }
    }
  }
}

输出:

Person 1
Person 4
Person 2
Person 5
Person 3

我们使用 C# 中的 Fisher-Yates 算法对 Person 类的对象列表进行了混排。我们创建了一种扩展方法,用于在 C# 中实现 Fisher-Yates 算法。要创建扩展方法,我们必须在另一个称为 ExtensionClassstatic 类中定义 Shuffle() 函数。

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 C# 中按值对字典排序

发布时间:2024/01/19 浏览次数:153 分类:编程语言

有两种主要方法可用于按 C# 中的值对字典进行排序:list 方法和 Linq 方法。使用 C# 中的 List 方法按值对字典进行排序。C# 字典数据结构以 key:value 对的形式存储数据。

在 C# 中更新字典值

发布时间:2024/01/19 浏览次数:72 分类:编程语言

本教程演示如何使用键作为索引来更新 C# 字典中的值。dictionary 是一种集合类型,与只能通过索引或值本身访问值的数组或列表不同,字典使用键和值对来存储其数据。

在 C# 中检查字典键是否存在

发布时间:2024/01/19 浏览次数:142 分类:编程语言

本文教我们如何检查或检测 C# 中是否存在字典键。Dictionary 倾向于映射键和值。它包含特定值映射到的特定键。不允许有重复的键,这是字典的全部目标。

C# 中的字典与哈希表

发布时间:2024/01/19 浏览次数:166 分类:编程语言

本指南将讨论 C# 中 Dictionary 和 Hashtable 之间的区别。你应该更喜欢哪一个?本指南将讨论 C# 中 Dictionary 和 Hashtable 之间的区别。

C# 将对象转换为 JSON 字符串

发布时间:2024/01/19 浏览次数:157 分类:编程语言

本文介绍如何将 C# 对象转换为 C# 中的 JSON 字符串的不同方法。它介绍了 JavaScriptSerializer().Serialize(),JsonConvert.SerializeObject()和 JObject.FromObject()之类的方法。

C# 解析 JSON

发布时间:2024/01/19 浏览次数:106 分类:编程语言

本文介绍如何使用 C# 解析 JSON 的不同方法,比如 JsonConvert.DeserializeObject(),JObject.Parse()和 JavaScriptSerializer()之类的方法。

获取 C# 中 foreach 循环当前迭代的索引

发布时间:2024/01/19 浏览次数:88 分类:编程语言

本文介绍如何在 C# 中获取 foreach 循环当前迭代的索引。在 C# 中,我们主要有两个循环,for 循环和 foreach 循环。foreach 循环被认为是最好的,因为它适用于所有类型的操作。

C# 中的十进制文字

发布时间:2024/01/19 浏览次数:194 分类:编程语言

本教程解释了 C# 中的十进制文字以及如何使用它在 C# 中初始化变量时,你可能必须明确指定你希望它用于数值数据类型的数据类型。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便