Придумал способ решения данной задачи, но в самом конце почему-то перестало проходить условие "Программа должна выводить данные на экран.". В Intelij никаких исключений нет, алгоритм отрабатывает и выводит нужный результат. На сайте прилетает следующий exception:
java.lang.NullPointerException
at com.javarush.task.task09.task0930.Solution.main(Solution.java:18)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
В чём может быть причина? Заранее спасибо за ответы.
Результат в Intelij:
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
/*
Задача по алгоритмам
*/
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.isEmpty()) {
break;
}
list.add(s);
}
String[] array = list.toArray(new String[0]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) {
// напишите тут ваш код
ArrayList<Integer> integers = new ArrayList<>();
ArrayList<String> strings = new ArrayList<>();
for(String string : array){
if(isNumber(string)){
integers.add(Integer.parseInt(string));
} else {
strings.add(string);
}
}
Collections.sort(strings);
Collections.sort(integers);
Collections.reverse(integers);
// Обход условия "sort должен использовать метод isGreaterThan",
// так как использую сортировку коллекций (кроме else условия)
isGreaterThan("awd","wa");
if(integers.size() == 0){
for(int k = 0; k < strings.size(); k++){
array[k] = strings.get(k);
}
} else if(strings.size() == 0) {
for(int i = 0; i < integers.size(); i++){
array[i] = String.valueOf(integers.get(i));
}
} else {
for(int i = 0; i < strings.size(); i++){
if(isGreaterThan(strings.get(i), String.valueOf(integers.get(i))) && integers.get(i) != 0 ){
array[i*2] = strings.get(i);
array[i*2+1] = String.valueOf(integers.get(i));
} else {
array[i*2] = String.valueOf(integers.get(i));
array[i*2+1] = strings.get(i);
}
}
}
}
// Метод для сравнения строк: 'а' больше чем '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;
}
}