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

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

22.11.2013, 00:09. Показов 5654. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru