zoukankan      html  css  js  c++  java
  • 生成大小为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 + ",");
                }
            }
    

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

  • 相关阅读:
    RNN-2-前向传播、BPTT反向传播
    RNN-1-参数共享、网络的展开、常见应用
    被围绕的区域
    语言模型的评价方法
    个性化推荐系统
    推荐系统-CTR-Wide&Deep
    推荐系统-CTR-总结
    推荐系统-CTR-PNN
    Local variable flag defined in an enclosing scope must be final or effective
    2.两数相加
  • 原文地址:https://www.cnblogs.com/wangdongjie0101/p/4754308.html
Copyright © 2011-2022 走看看