Форум программистов, компьютерный форум CyberForum.ru

Сортировка символов строки в алфавитном порядке - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 28, средняя оценка - 4.93
-Pathfinder-
Сообщений: n/a
11.01.2012, 19:38     Сортировка символов строки в алфавитном порядке #1
Помогите с заданием, какая-то ошибка, с указателем вроде. Нужно ввести строку и отсортировать входящие в нее символы по алфавиту.
Код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <stdio.h>
#include <iostream>
#include <string>
using namespace std;
int Comp(const void* a, const void* b){
    return *(char*)a-*(char*)b;
}
 int main(){
     cout<<"Vvedite stroku:";
     char text[256];
     scanf ("%s", text);
     char *p=text;
    qsort(text, sizeof(text)-1, sizeof(*text), Comp);
    for (; *p; ++p)
          cout<<""<<*p;
    system("PAUSE");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.01.2012, 19:38     Сортировка символов строки в алфавитном порядке
Посмотрите здесь:

C++ сортировка строки в алфавитном порядке
Сортировка строк в алфавитном порядке C++
Сортировка строк в алфавитном порядке C++
Сортировка в алфавитном порядке... C++
Сортировка структур в алфавитном порядке C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
CPPExecutor
1 / 1 / 0
Регистрация: 11.01.2012
Сообщений: 5
11.01.2012, 20:06     Сортировка символов строки в алфавитном порядке #2
А является ли крайней необходимостью использование быстрой сортировки в данной задаче? Ведь QSort в среднем работает за O(n*log(n)). А в худшем случае и того больше - O(n*n).

Не легче ли воспользоваться сортировкой подсчетом (работающей за линейное время)? Просто создать массив (для латинского алфавита из 26 элементов) и читая каждый символ строки, увеличивать значение соответствующего элемента массива. То есть просто посчитать какая буква сколько раз встретилась.

Как выводить результат, думаю, понятно.
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
11.01.2012, 20:16     Сортировка символов строки в алфавитном порядке #3
Цитата Сообщение от -Pathfinder- Посмотреть сообщение
qsort(text, sizeof(text)-1, sizeof(*text), Comp);
Здесь ошибка
C
1
qsort(text, strlen(text), sizeof(*text), Comp);
-Pathfinder-
Сообщений: n/a
11.01.2012, 20:19     Сортировка символов строки в алфавитном порядке #4
go, спасибо, теперь все заработало.
verena-12358
1 / 1 / 0
Регистрация: 12.10.2011
Сообщений: 165
29.03.2012, 01:03     Сортировка символов строки в алфавитном порядке #5
более простым способом можно решить???
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
29.03.2012, 02:54     Сортировка символов строки в алфавитном порядке #6
Цитата Сообщение от CPPExecutor Посмотреть сообщение
А является ли крайней необходимостью использование быстрой сортировки в данной задаче?
Является ли необходимостью городить весь этот лес с подсчётами и прочим, если стандартная функция вполне справляется с задачей? Где в условии сказано, что лимит времени - полторы наносекунды? В прочем в зависимости от реализации этот чудо-алгоритм может значительно дольше стандартной qsort отработать. По-моему лишние заморочки. Разве-что в плане практики полезно...

Для разнообразия
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <iostream>
#include <string>
#include <algorithm>
 
int main(){
    std::string str;
    
    while ( std::cout << "String: " && std::getline(std::cin, str) && ! str.empty() ){
        std::sort(str.begin(), str.end());
        std::cout << "Result: " << str << std::endl;
    }
    
    return 0;
}
Yandex
Объявления
29.03.2012, 02:54     Сортировка символов строки в алфавитном порядке
Ответ Создать тему
Опции темы

Текущее время: 16:19. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru