C++11. Есть multiset. Можно ли предать ему функцию, по которой буде сортировка? Например multiset, сортирующий строки по возрастанию количества символов в строке.
Пожалуйста, открывайте документацию прежде чем задавать вопросы тут. Вы порождаете спам, который решается запросом в поисковике.
Ссылка на документацию: (Удаленная ссылка на документацию на сайте cplusplus com, в поиске наберите multiset, вам необходима документация про конструктор данного класа)
(Для модераторов: прочитайте приложение после ответа, размещение ссылки в ответе не противоречит правилам сообщества)
Простенькая программа, как пример использования multiset и его сортировки строк по возрастанию. Also, для сортировки в multiset, необходимо просто создать функциональный объект (структуру с перегруженным оператором () ) и добавить её в шаблонный конструктор. Спасибо за отметку "Лучший ответ" и нажатую кнопочку "Спасибо" тут и в моем аккаунте.
for (const auto& el : multisetExample) { std::cout << el << std::endl; }
return 0; }
Приложение для модераторов: Ссылка не нарушает правил сообщества в соответствии с параграфом "§3. Услуги Сервиса", пунктом "Предоставление ответа на вопрос".
Цитата: Размещённый в Сервисе ответ должен содержать решение всех проблем, содержащихся в вопросе. Ответом на вопрос не может быть размещенная в Сервисе ссылка на другой интернет-источник, как и копия ответа, ранее размещённого в Сервисе другим Пользователем. Ответ на вопрос из области точных предметов, требующий проведения соответствующих расчётов, не может состоять только из конечного результата, а должен содержать также упомянутые выше расчёты. Ответ должен содержать объяснение проблемы, указанной Пользователем таким образом, чтобы он мог понять, как следует решать данную проблему.
Ответ содержит исчерпывающее решение проблемы, ссылка не является ответом на вопрос, а лишь дополнением к нему, как ровным счетом не является ссылкой на копию ответа на данном или стороннем сервисе. Пользователь способен понять решение проблемы и без ссылки на сторонний ресурс. >> Ссылка в данном случаи необходима как дополнительный справочный материал на документацию по языку программирования C++, так же наличие ссылки позволяет избежать появления банальных вопросов наподобие данного.
! Важно ! В частности прошу заметить что в соответствии с параграфом "§9. Политика конфиденциальности и контент третьих лиц", администрация сайта не запрещает размещать ссылки на Контент Третьих Лиц, ровно, как и не несет ответственности за данный контент.
В связи с вышеизложенным, прошу не удалять ссылку на сторонний ресурс.
clinteastwood2
Желательно для начала самому понять, что должна делать ваша программа, разобраться с STL и почитать документацию, благо msdn бесплатен) Незнаю верно ли понял, но как вариант: //Microsoft (R) C/C++ Optimizing Compiler Version 19.00.23506 for x64
template<typename T> void SortMultiset(multiset<T> m) { auto it = m.begin(); auto comp = m.value_comp(); do { cout << " " << *it << endl; } while ( comp(*it++, *m.rbegin()) ); }
int main() { MyMultiset<string> m; m.InsertElement("hi world"); m.InsertElement("simple text"); m.InsertElement("etc"); m.PrintSorted(SortMultiset); }
0 votes Thanks 0
clinteastwood2
Ууу как же вы ограничены) В том то и соль С++, хочу и пишу хоть функционально, какие проблемы? Мой пример показывает как можно делать, делать или нет решать ТС, если человек не может переделать кусочек кода под себя, вероятно ему не стоит продолжать, а брать готовое, ума не требует..
clinteastwood2
Если они, как и большинство, хотят слепо писать сами не понимая что и даже не зная когда стоит, а когда нет, применять те, или инные стили программирование, их дело, искренне надеюсь таких людей будет меньше, хотя что они здесь бы забыли.. Наверное, если бы я сказал что ООП поломанное и можно писать код без него вы бы не поверили, оно может и к лучшему..
clinteastwood2
Почитайте о том кто такой Алан Кей и о том каким он видел ООП
Answers & Comments
Verified answer
Пожалуйста, открывайте документацию прежде чем задавать вопросы тут.Вы порождаете спам, который решается запросом в поисковике.
Ссылка на документацию:
(Удаленная ссылка на документацию на сайте cplusplus com, в поиске наберите multiset, вам необходима документация про конструктор данного класа)
(Для модераторов: прочитайте приложение после ответа, размещение ссылки в ответе не противоречит правилам сообщества)
Простенькая программа, как пример использования multiset и его сортировки строк по возрастанию.
Also, для сортировки в multiset, необходимо просто создать функциональный объект (структуру с перегруженным оператором () ) и добавить её в шаблонный конструктор.
Спасибо за отметку "Лучший ответ" и нажатую кнопочку "Спасибо" тут и в моем аккаунте.
#include <set>
#include <string>
#include <iostream>
struct compareStructure
{
bool operator() (const std::string& firstValue, const std::string& secondValue) const
{
return ( firstValue.size() < secondValue.size() );
}
};
int main()
{
std::multiset<std::string, compareStructure> multisetExample;
multisetExample.insert("verylongSomeString");
multisetExample.insert("someString");
multisetExample.insert("longSomeString");
for (const auto& el : multisetExample)
{
std::cout << el << std::endl;
}
return 0;
}
Приложение для модераторов:
Ссылка не нарушает правил сообщества в соответствии с параграфом "§3. Услуги Сервиса", пунктом "Предоставление ответа на вопрос".
Цитата:
Размещённый в Сервисе ответ должен содержать решение всех проблем, содержащихся в вопросе.
Ответом на вопрос не может быть размещенная в Сервисе ссылка на другой интернет-источник, как и копия ответа, ранее размещённого в Сервисе другим Пользователем.
Ответ на вопрос из области точных предметов, требующий проведения соответствующих расчётов, не может состоять только из конечного результата, а должен содержать также упомянутые выше расчёты. Ответ должен содержать объяснение проблемы, указанной Пользователем таким образом, чтобы он мог понять, как следует решать данную проблему.
Ответ содержит исчерпывающее решение проблемы, ссылка не является ответом на вопрос, а лишь дополнением к нему, как ровным счетом не является ссылкой на копию ответа на данном или стороннем сервисе.
Пользователь способен понять решение проблемы и без ссылки на сторонний ресурс.
>> Ссылка в данном случаи необходима как дополнительный справочный материал на документацию по языку программирования C++, так же наличие ссылки позволяет избежать появления банальных вопросов наподобие данного.
! Важно !
В частности прошу заметить что в соответствии с параграфом "§9. Политика конфиденциальности и контент третьих лиц", администрация сайта не запрещает размещать ссылки на Контент Третьих Лиц, ровно, как и не несет ответственности за данный контент.
В связи с вышеизложенным, прошу не удалять ссылку на сторонний ресурс.
//Microsoft (R) C/C++ Optimizing Compiler Version 19.00.23506 for x64
#include <iostream>
#include <set>
#include <string>
using namespace std;
template<typename T>
class MyMultiset
{
public:
void InsertElement(const string& str)
{
m.insert(str);
}
void PrintSorted(void(*SortMultiset)(multiset<T>))
{
SortMultiset(m);
}
private:
multiset<T> m;
};
template<typename T>
void SortMultiset(multiset<T> m)
{
auto it = m.begin();
auto comp = m.value_comp();
do
{
cout << " " << *it << endl;
}
while (
comp(*it++, *m.rbegin())
);
}
int main()
{
MyMultiset<string> m;
m.InsertElement("hi world");
m.InsertElement("simple text");
m.InsertElement("etc");
m.PrintSorted(SortMultiset);
}