Форум программистов, компьютерный форум, киберфорум
C++/CLI
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
118 / 5 / 4
Регистрация: 05.05.2013
Сообщений: 336

Сортировка списка классов по определённому полю

13.04.2016, 18:35. Показов 1976. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброе утро. Не могу понять, как можно сделать сортировку вот такого класса?

C++
1
2
3
4
5
6
7
8
9
10
11
12
#ifndef NOTE_H
#define NOTE_H
 
using namespace System;
 
ref class Note {
private:
    String^ LastName;
// лишнее вырезано
public:
    String^ LastName_get();
};
где

C++
1
List<Note^> ^PhoneNote;
На C# это делается так:

C#
1
2
3
4
5
6
7
8
9
10
class CompareByLastName : IComparer<Note>
{
    public int Compare(Note x, Note y)
    {
        return string.Compare(x.LastName, y.LastName);
    }
}
 
// Вызов в другом месте, где List<Note> PhoneNote;
PhoneNote.Sort(new CompareByLastName());
Добавлено через 7 часов 41 минуту
1) Пытался так:
C++
1
2
3
4
        int Test(const Note^ x, const Note^ y)
        {
            return String::Compare(x->LastName_get(), y->LastName_get());
        }
Code
1
    1   IntelliSense: отсутствуют экземпляры функция "Note::LastName_get", соответствующие списку аргументов и объекту (объект содержит несоответствующие квалификаторы типа) тип объекта: const Note ^
2) Или так:
C++
1
2
3
4
5
6
7
8
9
10
11
        ref class CompareByLastName
        {
        public:
            int Compare(Note^ x, Note^ y)
            {
                return String::Compare(x->LastName_get(), y->LastName_get());
            }
        };
 
// где то в недрах...
        PhoneNote->Sort(gcnew CompareByLastName());
Code
1
Ошибка    7   error C2664: "void System::Collections::Generic::List<Note ^>::Sort(void)": невозможно преобразовать аргумент 1 из "PhoneBook::MainForm::CompareByLastName ^" в "System::Comparison<Note ^> ^"
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.04.2016, 18:35
Ответы с готовыми решениями:

Сортировка элементов массива классов по определенному полю
есть класс у которого есть несколько полей ,нужно сортировать массив класса за полем exp class Worker { private: string...

Сортировка списка структур по определенному полю
Помогите пожалуйста вписать в эту программу сортировку по цене или количеству ато не знаю как ее сюда приделать #include...

Обращение к определенному полю списка из запроса
Добрый день! Пользую Access 2007. Надо в запросе обратиться ко второй колонке поля со списком на форме. Там может быть название из...

1
Администратор
Эксперт .NET
 Аватар для tezaurismosis
9673 / 4825 / 763
Регистрация: 17.04.2012
Сообщений: 9,664
Записей в блоге: 14
14.04.2016, 19:28
Общие замечания по коду:
Цитата Сообщение от darksector Посмотреть сообщение
C++
11
String^ LastName_get();
Для этого существуют свойства:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
ref class Note
{
private:
    String^ m_LastName;
public:
    property String^ LastName
    {
        String^ get() {
            return m_LastName;
        }
 
        void set(String^ value) {
            m_LastName = value;
        }
    }
};
Если при вводе значения для имени никаких дополнительных проверок производиться не будет, то при использовании автосвойства код сократится до одной строки
C++
1
property String^ LastName;
________________________________________ _____
Вариант 1: с использованием отдельного класса-сравнителя. Он сделан вложенны, т.к. это распространённая в .NET практика для таких классов.
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
ref class Note
{
public:
    ref class NoteComparer : IComparer<Note^>
    {
    public:
        virtual Int32 Compare(Note^ lhs, Note^ rhs) override {
            return lhs->LastName->CompareTo(rhs->LastName);
        }
    };
 
    Note(String^ name) {
        LastName = name;
    }
 
    property String^ LastName;
};
 
int main(array<System::String ^> ^args) {
    List<Note^>^ phoneNote = gcnew List<Note^>();
    phoneNote->Add(gcnew Note(L"Владимир"));
    phoneNote->Add(gcnew Note(L"Сергей"));
    phoneNote->Add(gcnew Note(L"Михаил"));
    phoneNote->Sort(gcnew Note::NoteComparer());
 
    for each (Note^ note in phoneNote) {
        Console::WriteLine(note->LastName);
    }
    return 0;
}
Вариант 2: использование делегата Comparison<T>
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
ref class Note
{
public:
    Note(String^ name) {
        LastName = name;
    }
 
    property String^ LastName;
};
 
int CompareNotes(Note^ lhs, Note^ rhs) {
    return lhs->LastName->CompareTo(rhs->LastName);
}
 
int main(array<System::String ^> ^args) {
    List<Note^>^ phoneNote = gcnew List<Note^>();
    phoneNote->Add(gcnew Note(L"Владимир"));
    phoneNote->Add(gcnew Note(L"Сергей"));
    phoneNote->Add(gcnew Note(L"Михаил"));
    phoneNote->Sort(gcnew Comparison<Note^>(&CompareNotes));
 
    for each (Note^ note in phoneNote) {
        Console::WriteLine(note->LastName);
    }
    return 0;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.04.2016, 19:28
Помогаю со студенческими работами здесь

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

Сортировка массива структур по определенному полю
Всем привет...со структурами проблемка возникла...затупил)Задание состоит в следующем: Ввести структуру Студент с полями...

Сортировка классов наследования по числовому полю
Добрый вечер, столкнулся с проблемой сортировки. Имеется некоторый класс, у него есть класс-наследник, требуется провести сортировку по...

Сортировка массива классов по полю типа string
Дан массив объектов класса, одним из полей которого является переменная name типа string. Как можно отсортировать объекты этого массива в...

Сортировка списка по полю
У меня проблемка что то не могу понять вот такую делему.. есть список елементов у которых есть поля, я хочу отсортировать поле, но...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru