Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/26: Рейтинг темы: голосов - 26, средняя оценка - 4.73
1 / 1 / 0
Регистрация: 25.08.2011
Сообщений: 27

Сортировка слов из массива по алфавиту

22.11.2013, 00:09. Показов 5675. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Возникла проблема. Написал программу для сортировки слов по алфавиту. Без использования функций все работало.
Теперь выбивает ошибку.
Заранее благодарен за помощь.

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
#include<iostream> 
#include <locale.h>
using namespace std;
const int n=10; 
void sort(char *[]);
int main(){ 
    setlocale(LC_ALL, "Ukrainian");
    char *s[n]={"Ланівці","Копичинці‎","Заліщики‎","Чортків‎","Скалат‎","Зборів","Бережани","Шумськ","Кременець‎","Бучач‎"};
    int k=0;
    cout<<"До сортування:"<<endl;
    for(int i=0;i<n;i++) 
        cout<<s[i]<<endl;
    sort(&s[n]);
system("pause"); 
}
void sort(char *s[n])
{
    int k=0;
    for(int i=0;i<n-1;i++)
        for (int j=i+1; j<n; j++)
        {   k=0;
            if (s[i]!=s[j]){
                while (s[i][k]==s[j][k]) k++;
                if (s[i][k]>s[j][k]) 
                { 
                    char *s2=s[i]; 
                    s[i]=s[j]; 
                    s[j]=s2; 
 
                }
            }
        }
    cout<<endl<<"Після сортування:"<<endl;
    for(int i=0;i<n;i++) 
        cout<<s[i]<<endl; 
    
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
22.11.2013, 00:09
Ответы с готовыми решениями:

Сортировка слов из массива по алфавиту
Помогите пожалуйста найти ошибку. Неправильно сортирует слова. #include&lt;iostream&gt; using namespace std; const int n=4; ...

Сортировка массива слов по алфавиту
Составить программу, в которой организованы следующие действия: сортировка массива слов по алфавиту; выборка из массива слов,...

Сортировка массива слов по алфавиту (только по 4-му и 5-му символу)
Есть два файла, input.txt, в котором в столбик записано некоторое количество слов, и output.txt, в который необходимы вывести эти же слова...

5
 Аватар для newb_programmer
238 / 238 / 113
Регистрация: 03.09.2011
Сообщений: 558
22.11.2013, 11:09
Kenner, не знаю в этом ошибка или нет. передавайте в функцию размер массива
C++
1
2
3
4
5
6
7
void sort(char *,int);
 
char s[n]...
 
sort(s,n);
 
void sort(char *s,int n)
Добавлено через 3 минуты
и как оно у вас работало вот с этим
C++
1
if (s[i][k]>s[j][k])
помню сам когда-то так сравнивал слова и получился эпик фейл. вроде надо функцией типа strcmp() сравнивать
1
1 / 1 / 0
Регистрация: 25.08.2011
Сообщений: 27
22.11.2013, 13:53  [ТС]
Дальше ошибка. Когда я делал без функций, все отлично сравнивало. Сейчас понятия не имею что не так(

Добавлено через 19 минут
Все. Проблему решил. Вставляю код, если кому понадобится.

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
#include<iostream> 
#include <locale.h>
using namespace std;
const int n=10; 
void sort(char *[]);
int main(){ 
    setlocale(LC_ALL, "Ukrainian");
    char *s[n]={"Ланівці","Копичинці;","Заліщики;","Чортків;","Скалат;","Зборів","Бережани","Шумськ","Кременець;","Бучач;"};
    int k=0;
    cout<<"До сортування:"<<endl;
    for(int i=0;i<n;i++) 
        cout<<s[i]<<endl;
    sort(s);
system("pause"); 
}
void sort(char *s[n])
{
    int k=0;
    for(int i=0;i<n-1;i++)
        for (int j=i+1; j<n; j++)
        {   k=0;
            if (s[i]!=s[j]){
                while (s[i][k]==s[j][k]) k++;
                if (s[i][k]>s[j][k]) 
                { 
                    char *s2=s[i]; 
                    s[i]=s[j]; 
                    s[j]=s2; 
 
                }
            }
        }
    cout<<endl<<"Після сортування:"<<endl;
    for(int i=0;i<n;i++) 
        cout<<s[i]<<endl; 
    
}
0
835 / 643 / 101
Регистрация: 20.08.2013
Сообщений: 2,524
22.11.2013, 13:58
Цитата Сообщение от Kenner Посмотреть сообщение
sort(&s[n]);
Хм.. А оно вообще компилировалось?
0
1 / 1 / 0
Регистрация: 25.08.2011
Сообщений: 27
22.11.2013, 14:26  [ТС]
Qwertiy, да, но сразу выбивало ерор))
1
835 / 643 / 101
Регистрация: 20.08.2013
Сообщений: 2,524
22.11.2013, 16:54
Цитата Сообщение от Kenner Посмотреть сообщение
да
Тьфу.. Невнимательно смотрел. Конечно да - там же адрес строки, соответственно тип верный.
Кстати, с &s[0] работало бы правильно. Но просто s лучше
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.11.2013, 16:54
Помогаю со студенческими работами здесь

Сортировка массивов (Сортировка слов по алфавиту)
Объясните мне сортировку слов по алфавиту .Сравнивать целиком слова нельзя ?Есть ли какой нибудь быстрый способ?Какие то полезные функции...

Сортировка слов по алфавиту
немогу переделать программу( помогите плиз( программа распаралелина надо сделать второе мемо в котором будет в столбик сортированы слова...

Сортировка слов по алфавиту
Помогите написать программу: 1)Программа запрашивает ввести слово (10 раз) 2)Пользователь вводит любые слова (10 раз) 3)Программа...

Сортировка слов по алфавиту
MFC GUI. Собственно в чем задача:Нужно прочитать слова из файла, отсортировать их по алфавиту методом выбора и записать в новый файл. ...

Сортировка слов по алфавиту
Нашел вот такой код, пытаюсь применить: Создаю list, который хранит слова. И его хочу передать на сортировку. Вот таким способом...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита табличной части. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru