生成大小为100的数组,从1到100,随机插入,不连续,也不重复[C#]

生成大小为100的数组,从1到100,随机插入,不连续,也不重复.

实现思路

  1. 生成一个100位的集合listA,放1到100

  2. 创建一个空的集合listB,用来存放结果

  3. 创建一个变量c,临时存储生成的数组索引

  4. 创建一个变量d,临时存储集合listA的长度

  5. 每次生成后c后,对应的添加到listB中,然后在listA中删除

  6. 直到listA全部删除,结束

        /// <summary>
        /// recommend solution 
        /// </summary>
        public static void getArray2()
        {
            //1,生成一个100位的集合listA,放1到100
            IList<int> listA = new List<int>();
            for (int i = 0; i < 100; i++)
            {
                listA.Add(i + 1);
            }
            //2,创建一个空的集合listB,用来存放结果
            IList<int> listB = new List<int>();
            //3,创建一个变量c,临时存储生成的数组索引
            int c;
            //4,创建一个变量d,临时存储集合listA的长度
            int d;
            Random random = new Random();
            //6,直到listA全部删除,结束
            while (listA.Count > 0)
            {
                //5,每次生成后c后,对应的添加到listB中,然后在listA中删除
                d = listA.Count;               
                c = random.Next(0, d);
                listB.Add(listA[c]);
                listA.RemoveAt(c);
            }
            int[] arrayB = listB.ToArray<int>();
            foreach(var item in arrayB)
            {
                Console.Write(item + ",");
            }
        }

另一种思路,是随机生成数字后,判断是否是存在,如果存在,继续生成.然后再判断.
这样思路比较简单,缺点是可能造成死循环,或者大量的性能损耗.

转载于:https://www.cnblogs.com/wangdongjie0101/p/4754308.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值