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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 28, средняя оценка - 4.93
-Pathfinder-
Сообщений: n/a
#1

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

11.01.2012, 19:38. Просмотров 3615. Ответов 5
Метки нет (Все метки)

Помогите с заданием, какая-то ошибка, с указателем вроде. Нужно ввести строку и отсортировать входящие в нее символы по алфавиту.
Код:
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++
Сортировка структур в алфавитном порядке C++
C++ Сортировка структур в алфавитном порядке
Сортировка в алфавитном порядке 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++
3584 / 1364 / 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
9412 / 5435 / 917
Регистрация: 25.07.2009
Сообщений: 10,428
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     Сортировка символов строки в алфавитном порядке
Ответ Создать тему
Опции темы

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