Tested it with both numbers/strings only - still works but my code is not verified as correct, where did I go wrong?
package com.codegym.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
/*
Task about algorithms
*/
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[list.size()]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) {
ArrayList<String> sortedStrings = new ArrayList<>();
ArrayList<Integer> sortedNumbers = new ArrayList<>();
for (int i = 0; i < array.length; i++)
{
if(!isNumber(array[i]))
{
sortedStrings.add(array[i]);
} else if(isNumber(array[i]))
{
sortedNumbers.add(Integer.parseInt(array[i]));
}
}
for(int i = 0; i < sortedStrings.size(); i++)
{
for (int j = i + 1; j < sortedStrings.size(); j++)
{
if(isGreaterThan(sortedStrings.get(i), sortedStrings.get(j)))
{
String temp = sortedStrings.get(i);
sortedStrings.set(i, sortedStrings.get(j));
sortedStrings.set(j, temp);
}
}
}
int num;
for (int i = 0; i < sortedNumbers.size(); i++)
{
for (int j = i + 1; j < sortedNumbers.size(); j++)
{
if (sortedNumbers.get(i) < sortedNumbers.get(j))
{
num = sortedNumbers.get(i);
sortedNumbers.set(i, sortedNumbers.get(j));
sortedNumbers.set(j, num);
}
}
}
int n = 0;
int s = 0;
int i = 0;
while (i < array.length)
{
if ((i % 2 == 0 && sortedNumbers.size() > 0) && !isNumber(array[i]))
{
array[i] = sortedStrings.get(s);
s++;
} else if ((i % 2 != 0 && sortedStrings.size() > 0) && isNumber(array[i]))
{
array[i] = Integer.toString(sortedNumbers.get(n));
n++;
} else if (sortedStrings.size() == 0)
{
array[i] = Integer.toString(sortedNumbers.get(i));
} else if (sortedNumbers.size() == 0)
{
array[i] = sortedStrings.get(i);
}
i++;
}
}
// String comparison method: 'a' is greater than 'b'
public static boolean isGreaterThan(String a, String b) {
return a.compareTo(b) > 0;
}
// Is the passed string a number?
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 == '-') // The string contains a hyphen
|| (!Character.isDigit(c) && c != '-') // or is not a number and doesn't start with a hyphen
|| (i == 0 && c == '-' && chars.length == 1)) // or is a single hyphen
{
return false;
}
}
return true;
}
}