Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/15: Рейтинг темы: голосов - 15, средняя оценка - 4.73
3 / 3 / 1
Регистрация: 12.02.2015
Сообщений: 50

Написать модуль сортировки

16.10.2016, 23:34. Показов 3247. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать модуль сортировки, включающий в себя:
1. Метод, реализующий упорядочивание массива произвольного типа. Принцип сравнения
двух элементов должен передаваться в метод через делегат. Стандартные инструменты типа
Array.Sort и IComparable не использовать
2. Метод, позволяющий запустить в сортировку в отдельном потоке выполнения;
3. Событие, сигнализирующее о завершении сортировки.
Продемонстрировать работу модуля в многопоточном режиме.

Добавлено через 4 минуты
Начал писать. Вот что набросал.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
public delegate bool SortingMethod<T>(T x1, T x2);
 
   class SortingUnit<T>
   {
       public event EventHandler<SortingEventArgs<T>> SortingFinished;             
 
       public void CustomSort (T[] arr, SortingMethod<T> sortingMethod)
       {
           bool isSorted = false;
           T temp;
           while (!isSorted)
           {
               isSorted = true;
               for (int i = arr.GetLowerBound(0); i < arr.GetUpperBound(0); i++)
               {
                   if (sortingMethod(arr[i], arr[i + 1]))
                   {
                       temp = arr[i];
                       arr[i] = arr[i + 1];
                       arr[i + 1] = temp;
                       isSorted = false;
                   }
               }
           }                        
           SortingFinished?.Invoke(this, new SortingEventArgs<T>(arr));                        
       }
 
       public void RunSortInNewThread(T[] arr, SortingMethod<T> sortingMethod)
       {
           ThreadStart thStart = new ThreadStart( () => CustomSort(arr, sortingMethod) );
           Thread th = new Thread(thStart);
           th.Start();
       }
   }
Создал такой класс который содержит метод сортировки и метод, запускающий в новом потоке.

Помогите с написанием 3 пункта.

Добавлено через 1 минуту
значение я возвращаю в eventargs вот такой класс

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
class SortingEventArgs<T> : EventArgs
   {
       public T[] SortedArray { get; }       
 
       public SortingEventArgs(T[] sortedArray)
       {
           if (sortedArray!=null)
           {
               this.SortedArray = sortedArray;
           }
           else
           {
               throw new ArgumentException("SortedArray can't be null");
           }           
       }
   }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.10.2016, 23:34
Ответы с готовыми решениями:

Написать делегат для сортировки книг
Написать делегат, с помощью которого реализуется сортировка книг. Книга представляет собой класс с полями Название, Автор, Издательство и...

Необходимо написать программу для сортировки элементов
Необходимо написать программу, в которой методом быстрой сортировки нужно отсортировать прописные латинские буквы по возрастанию....

Сортировка методом простого выбора (пузырьком)
нужна помощь 1)написать программу сортировки методом простого выбора(методом пузырька) элементов двумерного массива,имеющих нечетные...

4
.NET senior
 Аватар для bax_tang
441 / 359 / 137
Регистрация: 23.09.2016
Сообщений: 980
16.10.2016, 23:39
Snow88, так у Вас же уже реализовано событие SortingFinished. В вызывающем коде после создания экземпляра класса SortingUnit подписываетесь на это событие обработчиком через += и... собственно всё.

Добавлено через 1 минуту
Ну разве что остаётся дождаться завершения потока, в котором крутится сортировка, чтобы спокойно отследить возникновение события.
0
3 / 3 / 1
Регистрация: 12.02.2015
Сообщений: 50
17.10.2016, 15:46  [ТС]
Поправьте пожалуйста что не так

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
static void arr_SortingFinished(object sender, EventArgs e)
        {
            Console.WriteLine("Sorting Finished");
        }
 
static void Main(string[] args)
        {
            SortingUnit<int>arr = new SortingUnit<int>();
            SortingUnit<int>[] SortedArray = new SortingUnit<int>[]{ };           
            arr.CustomSort(SortedArray, new Func<int, int, bool>(sortingMethod));
            arr.SortingFinished+= arr_SortingFinished;
            arr.RunSortInNewThread(SortedArray,new Func<int, int, bool>(sortingMethod));             
        }
Добавлено через 5 часов 7 минут
bax_tang, не подскажете пожалуйста что не так в последнем посте?
0
Эксперт .NET
 Аватар для insite2012
5548 / 4311 / 1218
Регистрация: 12.10.2013
Сообщений: 12,371
Записей в блоге: 2
17.10.2016, 16:52
Snow88, я бы немного подправил модуль сортировки, примерно так.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace ConsoleApplication37 {
    class Program {
        static void Main(string[] args) {
        }
    }
    public class SortingModule<T> {
        public event EventHandler SortingFinished;
 
        public void Sort(T[] arr, Func<T, T, bool> predicate) {
            //Тут сортируем как нам надо, а потом...
            OnSortingFinished(EventArgs.Empty);
        }
        public void SortAsync(T[] arr, Func<T, T, bool> predicate) {
            Task.Factory.StartNew(() => Sort(arr, predicate));
        }
        protected virtual void OnSortingFinished(EventArgs e) {
            if (SortingFinished != null) {
                SortingFinished(this, e);
            }
        }
    }
}
Логику внутри метода Sort() сами напишите, как хочется.
0
0 / 0 / 0
Регистрация: 03.04.2017
Сообщений: 7
04.04.2017, 22:42
Подскажите почему при использовании отдельного потока для сортировки, массив не сортируется. И как это можно исправить?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
static void Main(string[] args)
        {
            SortingModule<string> sortingModule = new SortingModule<string>();
            string[] array = new string[] {"bacd", "abcd", "ff", "rlk", "r", "cghjk", "dghjk" };
            Func<string, string, int> compareString = CompareString;
            
            sortingModule.CreateThreadForSorting(array, compareString);
            sortingModule.SortingFinished += (object o, EventArgs arg) => Console.WriteLine("Sorting Finished!");
            for (int i = 0; i < array.Length; i++)
            {
                Console.WriteLine(array[i]);
            }
 
            Console.ReadLine();
        }
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
public class SortingModule<T>
    {
        public event EventHandler SortingFinished;
 
        public void Sort(T[] arr, Func<T, T, int> compare)
        {
            if (compare == null)
            {
                throw new ArgumentNullException();
            }
 
            for (int i = 0; i < arr.Length; i++)
            {
                for (int j = i + 1; j < arr.Length; j++)
                {
                    if (compare(arr[j], arr[i]) > 0)
                    {
                        var tmp = arr[j];
                        arr[j] = arr[i];
                        arr[i] = tmp;
                    }
                }
            }
 
            SortingFinished?.Invoke(this, EventArgs.Empty);
        }
 
        public void CreateThreadForSorting(T[] arr, Func<T, T, int> compare)
        {
            Thread th = new Thread(() => this.Sort(arr, compare));
            th.Start();
        }
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.04.2017, 22:42
Помогаю со студенческими работами здесь

Написать приложение — графическую иллюстрацию сортировки методом выбора
Помогите пожалуйста дописать приложение на C# !!!(((((( В субботу 2.06.2012 уже защита, а я не могу доделать последнее задание, если у кого...

Написать модуль фильтрации изображения
Здравствуйте, помогите написать по С# Нужно написать модуль фильтрации изображения. Фильтры можно разделить на две категории: точечные и...

Написать программу, которая наглядно иллюстрирует работу следующих методов сортировки
Примером сортировки по двум ключам может служить список файлов, имеющих одинаковые имена и разные расширения. Список упорядочен по именам,...

Написать код программы сортировки массива размерностью от 1 до N одним из указанных методов
Задание. Написать код программы сортировки массива размерностью от 1 до N одним из указанных методов, разработать блок-схему алгоритма...

Написать программу которая релизует виды сортировки и сравнивает их на одном и том же списке данных
Помогите написать программу, совершенно не разбираюсь в сортировках Написать программу которая реализует след. виды сортировок:...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью в конфигурации КА2. Данные берутся из регистра сведений, по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru