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

Сортировать по возрастанию(по алфавиту) - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.78
BaGLaN
0 / 0 / 0
Регистрация: 04.07.2012
Сообщений: 7
09.07.2012, 18:03     Сортировать по возрастанию(по алфавиту) #1
2. Символьный массив, состоящий из 15и символов. Сортировать их по возрастанию(по алфавиту). Например:
Дано: ф а п р б г д . . . .
В итоге:а б г д п р ф . . . .
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Flexoid1
5 / 5 / 0
Регистрация: 08.07.2012
Сообщений: 20
09.07.2012, 18:11     Сортировать по возрастанию(по алфавиту) #2
Почитай Алгоритмы сортировок
Кот Ангенс
 Аватар для Кот Ангенс
317 / 267 / 37
Регистрация: 24.05.2012
Сообщений: 629
09.07.2012, 18:19     Сортировать по возрастанию(по алфавиту) #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <algorithm>
#include <iostream>
#include <iterator>
 
using namespace std;
 
int main() {
    const unsigned N = 15;
    char ar[N];
    for (char i = 0; i < N + N; i++)
        cin.get(i & 1?: ar[i]);
    sort(ar, ar + N);
    copy(ar, ar + N, ostream_iterator<int, char>(cout, " "));
}
Sylar9
-20 / 55 / 2
Регистрация: 04.09.2011
Сообщений: 1,888
Записей в блоге: 1
09.07.2012, 19:49     Сортировать по возрастанию(по алфавиту) #4
Цитата Сообщение от Кот Ангенс Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <algorithm>
#include <iostream>
#include <iterator>
 
using namespace std;
 
int main() {
    const unsigned N = 15;
    char ar[N];
    for (char i = 0; i < N + N; i++)
        cin.get(i & 1?: ar[i]);
    sort(ar, ar + N);
    copy(ar, ar + N, ostream_iterator<int, char>(cout, " "));
}
а как в обратном порядке отсортировать
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
09.07.2012, 19:57     Сортировать по возрастанию(по алфавиту) #5
Цитата Сообщение от Кот Ангенс Посмотреть сообщение
cin.get(i & 1?: ar[i]);
Это как?
Catstail
Модератор
 Аватар для Catstail
21427 / 10212 / 1664
Регистрация: 12.02.2012
Сообщений: 17,082
09.07.2012, 20:18     Сортировать по возрастанию(по алфавиту) #6
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
31
32
33
34
35
36
37
38
39
40
#include "iostream.h"
 
void SortCArr(char * A, int n)
{
    int i,j,tmp;
    for (i=0; i<n-1; i++)
        for (j=i+1; j<n; j++)
        {
            if (A[i] > A[j]) 
            {
                tmp=A[i];
                A[i]=A[j];
                A[j]=tmp;
            }
        }
}
 
int main(int argc, char* argv[])
{
 
    char Arr[]={'g','w','q','y','x','c','b'};
 
    int i,asz=sizeof(Arr)/sizeof(char);
 
    cout << asz << endl;
 
    cout << "Initial Array:" << endl;
 
    for (i=0; i<asz; i++) cout << Arr[i] << " ";
 
    SortCArr(Arr,asz);
 
    cout << endl << "Array after sorting:" << endl;
 
    for (i=0; i<asz; i++) cout << Arr[i] << " ";
 
    cout << endl;
 
    return 0;
}
Миниатюры
Сортировать по возрастанию(по алфавиту)  
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.07.2012, 10:09     Сортировать по возрастанию(по алфавиту)
Еще ссылки по теме:

Как сортировать массив по алфавиту C++
Сортировать слова по количеству букв (по возрастанию) C++
C++ Сортировать массив K по возрастанию, переставив соответствующие фрагменты в массиве X

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

Или воспользуйтесь поиском по форуму:
Кот Ангенс
 Аватар для Кот Ангенс
317 / 267 / 37
Регистрация: 24.05.2012
Сообщений: 629
10.07.2012, 10:09     Сортировать по возрастанию(по алфавиту) #7
Цитата Сообщение от alsav22 Посмотреть сообщение
Это как?
Хм, действительно, не работает.
C++
1
2
3
4
if (i & 1)
    cin.get();
else
    cin.get(ar[i]);
Yandex
Объявления
10.07.2012, 10:09     Сортировать по возрастанию(по алфавиту)
Ответ Создать тему
Опции темы

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