В задаче 100% есть другие ошибки, но про них говорить не нужно, пожалуйста. Буду сама разбираться.
Но пока мне мешает увидеть хоть какой-то результат этот NP. Помогите его, пожалуйста, отыскать. Буду очень благодарна.
java.lang.NullPointerException
at com.javarush.task.task09.task0930.Solution.isNumber(Solution.java:94)
at com.javarush.task.task09.task0930.Solution.sort(Solution.java:37)
at com.javarush.task.task09.task0930.Solution.main(Solution.java:23)
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.*;
/*
Задача по алгоритмам
*/
public class Solution {
public static void main(String[] args) throws Exception {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
ArrayList<String> list = new ArrayList<>();
while (true) {
String s = reader.readLine();
if (s == null || s.isEmpty()) break;
list.add(s);
}
String[] array = list.toArray(new String[100]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) {
ArrayList<String> st = new ArrayList<>();
ArrayList<String> num = new ArrayList<>();
//собираем массив чисел и массив слов
for (int i = 0; i < array.length; i++){
String x = array[i];
if (isNumber(x)){
num.add(x);
}
else{
st.add(x);
}
}
// сортируем массив чисел
Collections.sort(num);
Collections.reverse(num);
// сортируем массив строк
int k = st.size();
while (k > 0){
for (int j = 1; j < st.size(); j++){
boolean result = isGreaterThan((st.get(j)), (st.get(j-1)));
if (result = true) {
String x = st.get(j-1);
st.add(j-1, st.get(j));
st.add(j, x);
}
}
k--;
}
// меняем основной массив
for (int m = 0; m < array.length; m++){
if (isNumber(array[m])){
array[m] = num.get(0);
num.remove(0);
}
else{
array[m] = st.get(0);
st.remove(0);
}
}
}
// Метод для сравнения строк: 'а' больше чем 'b'
public static boolean isGreaterThan(String a, String b) {
return a.compareTo(b) > 0;
}
// Переданная строка - это число?
public static boolean isNumber(String s) {
if (s.length() == 0) return false;
char[] chars = s.toCharArray();
for (int i = 0; i < chars.length; i++) {
char c = chars[i];
if ((i != 0 && c == '-') // Строка содержит '-'
|| (!Character.isDigit(c) && c != '-') // или не цифра и не начинается с '-'
|| (chars.length == 1 && c == '-')) // или одиночный '-'
{
return false;
}
}
return true;
}
}