Форум программистов, компьютерный форум, киберфорум
Наши страницы
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.51/136: Рейтинг темы: голосов - 136, средняя оценка - 4.51
Johnlion
62 / 2 / 1
Регистрация: 11.05.2011
Сообщений: 666
#1

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

16.04.2013, 17:54. Просмотров 24997. Ответов 3
Метки нет (Все метки)

Задаю строку, разбиваю ее на слова и заношу в массив wordsArr. Осталось только эти слова по алфавиту отсортировать в массиве. Подскажите, пожалуйста, как это сделать?

сейчас вылетает ошибка java.lang.NullPointerException на строке Arrays.sort(wordsArr);

Main
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class CMain_lab5 {
    public static void main(String[] args) {
        
        CAlphabet_lab5 obj = new CAlphabet_lab5();
        
        obj.receiveWords();
        obj.sortWords();
        
        for (int i=0; i<obj.reallength; i++)
        {
            System.out.println(obj.wordsArr[i]);
        }
    }
}
Решение задачи
Java
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
import java.util.Arrays;
import java.util.Scanner;
 
public class CAlphabet_lab5 {
 
    Scanner sc = new Scanner(System.in);
    String str, wordsArr[];
    char space = ' ';
    int beginOfWord = 0, w = 0, reallength;
    //StringBuilder out = new StringBuilder();
    
    void receiveWords()
    {
        System.out.print("Введите строку из нескольких слов: ");
        str = sc.nextLine();
        
        String[] wordsArr = new String[15];
        
        
        for (int i=0; i<str.length(); i++)
        {
            if (str.charAt(i) == space)
            {
                //out.append(str.substring(beginOfWord,i));
                wordsArr[w] = str.substring(beginOfWord,i);
                w++;
                beginOfWord = i+1;
            }
        }
        
        wordsArr[w] = str.substring(beginOfWord,str.length());
        reallength = w+1;
        
        for (int d=0; d<reallength; d++)
            System.out.print(wordsArr[d]+" ");
    }
    
    void sortWords()
    {   
        System.out.println("До сортировки: "+Arrays.toString(wordsArr));
        Arrays.sort(wordsArr);
        System.out.println("После сортировки: "+Arrays.toString(wordsArr));
        
        /*for (int j = 0; j < reallength; j++)
        {
            for (int i = j + 1; i < reallength; i++)
            {
                if (wordsArr[i].compareTo(wordsArr[j]) < 0)
                {
                    String t = wordsArr[j];
                    wordsArr[j] = wordsArr[i];
                    wordsArr[i] = t;
                }
            }
        }*/
    }
 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.04.2013, 17:54
Ответы с готовыми решениями:

Java, сортировка строк по алфавиту
Добрый день, у меня есть вопрос как сделать сортировку строк в программе по...

Тривиальная сортировка строк файла по алфавиту
Вот этот код тривиально сортирует строки файла по алфавиту. import...

Сортировка в массиве строк
Можно ли как то просто организовать сортировку строк , не по алфавиту , а по...

Сортировка по алфавиту
Всем привет, помогите пожалуйста исправить ошибку. С моими знаниями даже не...

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

3
dr_yand
156 / 138 / 14
Регистрация: 13.03.2013
Сообщений: 321
Записей в блоге: 3
16.04.2013, 18:29 #2
Цитата Сообщение от Johnlion Посмотреть сообщение
String str, wordsArr[];
и
Цитата Сообщение от Johnlion Посмотреть сообщение
String[] wordsArr = new String[15];
Два раза объявлен массив
1
Johnlion
62 / 2 / 1
Регистрация: 11.05.2011
Сообщений: 666
16.04.2013, 19:07  [ТС] #3
УРА! Вместо всего вот этого, что выше написано, можно всего лишь написать так:

Java
1
2
3
4
5
6
System.out.print("string input > ");
String line = new Scanner(System.in).nextLine();
String[] words = line.split("\\s+");
System.out.println("Unsorted array: " + Arrays.toString(words));
Arrays.sort(words);
System.out.println("Sorted array: " + Arrays.toString(words));
Спасибо exiqa, задача решена
0
mutagen
2565 / 2238 / 257
Регистрация: 14.09.2011
Сообщений: 5,185
Записей в блоге: 18
17.04.2013, 00:39 #4
Ага ага, пульните на вход слово Ёжик среди других и посортируйте
Можно ещё Йод
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.04.2013, 00:39

Сортировка текста по алфавиту
Нужна помощь. нужно написать консольную программу, которая бы сортировала текст...

Сортировка карт по алфавиту
Есть 52 карты в АрайЛист нужно отсортировать их по алфавиту переписав compare...

Сортировка списка файлов по алфавиту
Доброго всем времени суток!=) Я сиииильно начинающий, вот что-то сам по себе...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru