Здравствуйте, я пытаюсь упорядочить массив от небольшого значения до большого значения, но он не работает - PullRequest
0 голосов
/ 28 мая 2020

Пытаюсь устроить массив из маленького значения в рост, а эта функция почему-то не работает (SmallToGrow), остальное отлично. Спасибо.

Есть вспомогательные функции, которые я использую, и это отличный факт, только функция (SmallToGrow) у меня не работает, и я не могу понять почему. Я бы хотел всех, кто может помочь. Спасибо, введите здесь код

  //this check if all cells equals
   public bool EverybodyAreEqual(int [] array)
        {
            for (int i = 0; i < array.Length - 1; i++)
                if (array[i] != array[i + 1])
                return false;
            return true;
        }
//This function changes all the values ​​in the array that contain the -numInArray- value you entered, 
 // to the -numChanged- value you entered
 public void ChangNumWhere(ref  int []  array,int numInArray,int numChanged)
        {
            for (int i = 0; i < array.Length; i++)
                if (array[i] == numInArray)
                    array[i] = numChanged;
        }
   //A function that returns the number of values ​​that are not equal in the array
    public int NumDifferentArray(int [] array)
        {
             int[] arr = new int[array.Length];
               for (int i = 0; i < arr.Length; i++)
                  arr[i] = array[i];
             bool con = true;
             int contain = 0;
             int index = 0;
             for(int i=0; con;i++)
             {
                if (!arr.Contains(i))
                 {
                  contain = i;
                  con = false;
                }
             }
            while(!this.EverybodyAreEqual(arr))
            {
                for (int i = 0; i < arr.Length; i++)
                    if (arr[i] != contain)
                    {
                        this.ChangNumWhere(ref arr, arr[i], contain);
                        index++;
                    }             
            }
            return index;
        }
 public int HowTimesExsist(int [] array,int num)
        {
            int index = 0;
            for(int i=0;i<array.Length;i++)
            {
                if (array[i] == num)
                    index++;
            }
            return index;
        }
  /// This function returns a minimum value as required,
  /// for example if you requested 0 the smallest value is returned,
  /// if 1 is returned one above it and so on,
  /// if the index is greater than the length of the array the largest number is returned
    public int MinBottom(int[] array, int num)
        {
            if (num < 0)
                throw new Exception("num canot be less then 0");         
            int max = this.MaxArray(array);
            while (num > 0)
            {
               int min = this.MinArray(array);
               for (int i = 0; i < array.Length; i++)             
                    if(array[i]==min)
                         array[i] = max;            
                num--;
            }
            return this.MinArray(array);               
        }
 public  int[]  SmallToGrow(int [] array)
        {
            int i = 0;
            int[] arr = new int[array.Length];
             for (int j = 0; j < this.NumDifferentArray(array); j++)
                for (int b = 0; b < this.HowTimesExsist(array, MinBottom(array, j)); i++, b++)
                    arr[i] = this.MinBottom(array, j);
            return arr;
         }

Ответы [ 2 ]

0 голосов
/ 28 мая 2020

Похоже, вы в значительной степени модернизируете некоторые общие функции в System.Collections.Generic и System.Linq -

public bool EverybodyAreEqual(int[] array)
{
    // If all items are the same,
    // there should only be one distinct item in the collection
    return array.Distinct().Length == 1;
}

public int NumDifferentArray(int[] array)
{
    // Group the numbers in the array and
    // count the number of groups with only one item
    return array.GroupBy(number => number).Where(g => g.Count() == 1);
}

public int HowTimesExsist(int[] array, int num)
{
    // Count the number of times a number appears in the array
    return array.Count(n => n == num);
}

/// This function returns a minimum value as required,
/// for example if you requested 0 the smallest value is returned,
/// if 1 is returned one above it and so on,
/// if the index is greater than the length of the array the largest number is returned
public int MinBottom(int[] array, int num)
{
    if (num < 0)
    {
        // Be specific about the type of exception you are throwing
        throw new ArgumentOutOfRangeException(nameof(num));
    }

    // Sort a copy of your array
    var sorted = Array.Copy(array);
    Array.Sort(sorted);

    // If there are any items over the specified minimum, return those
    // otherwise, return the highest number in the array
    // Using LastOrDefault for the maximum will return 0 if the initial array is empty
    var itemsOverMinimum = sorted.Where(n => n >= num);
    return itemsOverMinimum.Any() ? itemsOverMinimum.First() : sorted.LastOrDefault();
}

public int[] SmallToGrow(int[] array)
{
    // Because you are returning an array, that implies that the original array should not change
    // Copy the array and sort it
    var copy = Array.Copy(array);
    Array.Sort(copy);
    return copy;
}

Я видел, что вы упомянули, что пытаетесь найти альтернативные способы достижения sh некоторые из этих вещей, и я хочу дать вам несколько советов по этому поводу.

Я думаю, это довольно круто, что вы хотите бросить вызов самому себе. Однако эта конкретная функция c является частью библиотек System. Одна из лучших составляющих работы с C# - это то, как много такого рода вещей уже написано для вас, и эта функциональность, добавленная к System, означает, что Microsoft считает, что эти части являются основными (каламбурными) строительными блоками для работает в. NET.

Если ваш проект не предназначен специально для написания лучшего алгоритма сортировки, вы не собираетесь писать его лучше, чем в этих библиотеках. Я занимаюсь этим какое-то время, и у меня тоже не будет возможности.

Но это не значит, что вам следует перестать учиться. Вместо этого я бы посоветовал вам посмотреть в исходном коде github методы, которые я использовал в приведенных выше фрагментах. Я думаю, что это, вероятно, будет намного полезнее, чем переработка этого материала с нуля.

https://github.com/dotnet/runtime/blob/master/src/libraries/System.Linq/src/System/Linq/Distinct.cs https://github.com/dotnet/runtime/blob/master/src/libraries/System.Linq/src/System/Linq/Grouping.cs https://github.com/dotnet/runtime/blob/master/src/libraries/System.Linq/src/System/Linq/Where.cs https://github.com/dotnet/runtime/blob/master/src/libraries/System.Linq/src/System/Linq/Count.cs

0 голосов
/ 28 мая 2020

Почему бы вам не использовать вместо этого список? К ним прикреплен метод, который сортирует все за вас.

List<int> sortInt = new List<int>() { 2, 5, 1, 50, 258, 87, 63, 52, 100, 85, 21 };

sortInt.Sort();

Возвращает их в числовом порядке с [0] равным 1 и [10] равным 258.

вы можете затем превратить список в массив с sortint.ToArray();.

Edit

Как упоминалось в dymanoid, вы можете просто использовать свой массив и просто запустить с ним метод array.Sort (). Узнавайте что-то новое каждый день.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...