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

Оптимальный алгоритм сортировки

23.02.2018, 13:23. Показов 937. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!

Есть некий класс:

C#
1
2
3
4
5
public class Person
{
  public string Name { get; set; }
  public int Age { get; set; }
}
Также имеется List<Person> Persons, в котором может быть значительное количество объектов типа Person (5-10 миллионов).
Стоит простая задача: отсортировать список Persons по полю Age в порядке возрастания, затем отправить отсортированный список в конструктор ObservableCollection.

Тестировал две реализации:
1. OrderBy(o => o.Age) - по невыясненной причине периодически данная операция зависает.
2. Создал отдельный класс-наследник PersonsComparer: IComparer<Person> примерно следующего содержимого:

C#
1
2
3
4
public int Compare(Person x, Person y)
{
  return ReferenceEquals(x, y) ? 0 : x.Age.CompareTo(y.Age);
}
И затем сортирую список: Persons.Sort(new PersonsComparer()). Данная реализация работает, однако несколько медленнее, чем OrderBy (приблизительно в два раза).

Поэтому, хотелось бы узнать, существуют ли эффективные алгоритмы сортировки для моего случая? И если да, то как ими пользоваться?

Спасибо!
2
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.02.2018, 13:23
Ответы с готовыми решениями:

Вывести элементы, присутствующие в обоих массивах А и В. Алгоритм сортировки - подсчетом, алгоритм поиска - двоичный
Вывести элементы, присутствующие в обоих массивах А и В. Алгоритм сортировки - подсчетом, алгоритм поиска - двоичный. Помогите пожалуйста...

Оптимальный алгоритм сортировки
Камрады! Есть функция/процедура f(m,n), которая получает 2 номера и возвращает n,m (n&gt;m) т.е. &quot;сортирует&quot; от большего...

оптимальный алгоритм
найти сумму простых чисел от 1 до A program kl; var s,m,p,n,A:integer; begin read (A); for n:=1 to A do begin p:=1; for...

1
Эксперт .NET
 Аватар для Wolfdp
3790 / 1767 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
23.02.2018, 19:15
попробуйте использовать https://msdn.microsoft.com/ru-... .110).aspx , а еще лучше -- унаследуйтесь от него, и переопределите Add/Remove/Clear с выдачей уведомлений
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.02.2018, 19:15
Помогаю со студенческими работами здесь

Оптимальный алгоритм рисования линий
1) Является ли алгоритм рисования линии перебором точек оптимальным? for(float i=Xmin, j; i&lt;=Xmax; i+=0.001) { j = k*i + b; ...

Подсчеты в строю - оптимальный алгоритм
Здравствуйте. Есть задача. Условие следующее: Так, например, если в шеренге стоят 4 солдата ростом {h}_{1} = 178, {h}_{2} = 180,...

Перемножение матриц. Оптимальный алгоритм
Доброе время суток! Объясните пожалуйста почему такой алгоритм перемножения матриц: for (int i = 0; i &lt; nSize; i++) { for...

Перебор цифр и оптимальный алгоритм
Всем, добрый день. Есть набор цифр от 1 до 5. В числе может быть от 1 до 15 цифр. Например, 12345, 341, 555554324 и т.д. Какая...

Оптимальный алгоритм амплитудного демодулятора
Доброго времени суток. Возникла задача - детектирование АМ сигнала с синусоидальной несущей в 4 кГц. Есть идея реализовать детектор...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
1С: Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru