时间:2021-05-20
本文实例讲述了C#实现对数组进行随机排序类。分享给大家供大家参考。具体如下:
这个一个扩充C#随机数发生器的类,可以随机生成指定范围的数字,可以随机对数组进行排序,非常好用
using System;namespace DotNet.Utilities{ /// <summary> /// 使用Random类生成伪随机数 /// </summary> public class RandomHelper { //随机数对象 private Random _random; #region 构造函数 /// <summary> /// 构造函数 /// </summary> public RandomHelper() { //为随机数对象赋值 this._random = new Random(); } #endregion #region 生成一个指定范围的随机整数 /// <summary> /// 生成一个指定范围的随机整数,该随机数范围包括最小值,但不包括最大值 /// </summary> /// <param name="minNum">最小值</param> /// <param name="maxNum">最大值</param> public int GetRandomInt(int minNum, int maxNum) { return this._random.Next(minNum, maxNum); } #endregion #region 生成一个0.0到1.0的随机小数 /// <summary> /// 生成一个0.0到1.0的随机小数 /// </summary> public double GetRandomDouble() { return this._random.NextDouble(); } #endregion #region 对一个数组进行随机排序 /// <summary> /// 对一个数组进行随机排序 /// </summary> /// <typeparam name="T">数组的类型</typeparam> /// <param name="arr">需要随机排序的数组</param> public void GetRandomArray<T>(T[] arr) { //对数组进行随机排序的算法:随机选择两个位置,将两个位置上的值交换 //交换的次数,这里使用数组的长度作为交换次数 int count = arr.Length; //开始交换 for (int i = 0; i < count; i++) { //生成两个随机数位置 int randomNum1 = GetRandomInt(0, arr.Length); int randomNum2 = GetRandomInt(0, arr.Length); //定义临时变量 T temp; //交换两个随机数位置的值 temp = arr[randomNum1]; arr[randomNum1] = arr[randomNum2]; arr[randomNum2] = temp; } } #endregion }}希望本文所述对大家的C#程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C#使用linq对数组进行筛选排序的方法。分享给大家供大家参考。具体如下:usingSystem;usingSystem.Collections.
本文实例讲述了C#对list列表进行随机排序的方法。分享给大家供大家参考。具体实现方法如下:publicListRandomSortList(ListListT
编写程序,实现将输入的字符串转换为一维数组,并使用选择排序法对数组进行排序。思路如下:点击"生成随机数"按钮,创建Random随机数对象;使用JTextArea
本文实例讲述了C#实现的二维数组排序算法。分享给大家供大家参考,具体如下:classOrder{//////对二维数组排序//////排序的二维数组///排序根
JavaScript实现多维数组、对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序。sort()方法用于对数组的元素进行排序。语法如下