Problem z funkcją do sortowania

Odpowiedz Nowy wątek
2019-10-09 17:06
0

Cześć, otóż napisałem taki program, który sortuje imiona z tablicy od najdłuższego do najkrótszego, jednakże jest pewien problem, który nie wiem zbytnio jak rozwiązać, szukanie w internecie też nic nie dało, mam problem z wypisywaniem w odpowiedniej kolejności tych imion, a mianowicie program jest wrażliwy na duże i małe litery, gdzie zawsze wypisuje te wyrazy z dużą literą na początku, a potem przechodzi do tych z małą literą(oczywiście jeżeli ów wyrazy mają taką samą długość). Macie może jakieś pomysły jak rozwiązać ten problem? Kod niżej:

#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
bool porownaj(string, string);
int main()
{
    string lista[] = { "ola","Jan","robert","Patryk","maciek" };
    cout << "Imiona przed sortowaniem: " << endl;
    for(int i=0;i<5;i++)
    {
        cout << i+1 <<". " <<lista[i]<< endl;
    }
    sort(lista, lista + 5, porownaj);

    cout << "===============================" << endl;
    cout << "Imiona po sortowaniu: " << endl;
    for (int i = 0; i < 5; i++)
    {
        cout << i + 1 << ". " << lista[i] << endl;
    }

}

bool porownaj(string a, string b)
{
if (a.length() != b.length()) return a.length() > b.length();
    else return a < b;
} 

Pozostało 580 znaków

2019-10-09 20:19
2

wyatarczy:

return string1.length > string2.length;

lub użyj standardu:

sort(lista, lista + 5, greater<string>());

Wykonuję programy na zamówienie, pisać na Priv.
Asm/C/C++/Pascal/Delphi/Java/C#/PHP/JS oraz inne języki.
edytowany 1x, ostatnio: _13th_Dragon, 2019-10-09 20:23
Przyjmując, że autor pisze w >= C++14 wystarczy std::greater<>(), nie ma potrzeby jawnie podawać typu. - satirev 2019-10-09 21:11

Pozostało 580 znaków

Odpowiedz
Liczba odpowiedzi na stronę

1 użytkowników online, w tym zalogowanych: 0, gości: 1, botów: 0