Будь-ласка допоможіть об"єднати два масиви в один. даним способом не виходить тому що виходить за границю масиву. пишуть що можна брати окремо лічильники для двох масивів, але я не розумію як то зробити. Буду вдячний за допомогу.
83 for(int i = 0; i<array.length;i++)
84 {
85 if (isNumber(array[i]))
86 {
87 array[i] = String.valueOf(numbersArr[i]);
88 }
89 else
90 {
91 array[i] = wordsArr[i];
92 }
93 }
package com.javarush.task.task09.task0930;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
/*
Задача по алгоритмам
*/
public class Solution {
public static void main(String[] args) throws Exception {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
ArrayList<String> list = new ArrayList<>();
try{
while (true) {
String s = reader.readLine();
if (s.isEmpty()) break;
list.add(s);
}
}
catch (NullPointerException e){}
String[] array = list.toArray(new String[0]);
sort(array);
for (String x : array) {
System.out.println(x);
}
}
public static void sort(String[] array) throws NullPointerException {
// напишите тут ваш код
ArrayList <String> numbers = new ArrayList<>();
ArrayList <String> words = new ArrayList<>();
for(int i = 0; i< array.length;i++)
{
if (isNumber(array[i]))
{
numbers.add(array[i]);
}
else
{
words.add(array[i]);
}
}
String [] numbersArr0 = new String[numbers.size()];
numbers.toArray(numbersArr0);
int [] numbersArr = new int[numbers.size()];
for (int c = 0; c<numbersArr.length;c++)
{
numbersArr[c] = Integer.parseInt(numbersArr0[c]);
}
String[] wordsArr =new String[words.size()];
words.toArray(wordsArr);
for(int p = numbersArr.length-1 ; p >= 0;p--)
{
for (int k = p+1;k<numbersArr.length;k++)
{
if( numbersArr[p] < numbersArr[k] )
{
int tmp = numbersArr[k];
numbersArr[k] = numbersArr[p];
numbersArr[p] = tmp;
}
}
}
for (int l = wordsArr.length-1;l>=0;l--)
{
for (int x = l+1;x<wordsArr.length;x++)
{
if(isGreaterThan(wordsArr[l],wordsArr[x]))
{
String buffer = array[l];
array[l] = array[x];
array[x] = buffer;
}
}
}
for(int i = 0; i<array.length;i++)
{
if (isNumber(array[i]))
{
array[i] = String.valueOf(numbersArr[i]);
}
{
array[i] = wordsArr[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;//для String
}
}
return true;//для числа
}
}