Все правильно. А ругается, подскажите.
package com.javarush.task.pro.task09.task0906;
import java.util.regex.Pattern;
/*
Двоичный конвертер
Один из алгоритмов перевода представления двоичного числа в десятичное число следующий:
for (int i = 0; i < длины двоичного представления; i++) {
десятичное число = десятичное число + число из двоичного представления * на 2 в степени i
}
Изначально берется крайнее правое число из двоичного представления. С каждой итерацией цикла берется следующее число ближе к началу двоичного представления.
Подсказка: чтобы возвести число к степени можно использовать метод Math.pow(число, степень).
Метод main() не принимает участие в тестировании.
*/
public class Solution {
public static void main(String[] args) {
int decimalNumber = Integer.MAX_VALUE;
System.out.println("Десятичное число " + decimalNumber + " равно двоичному числу " + toBinary(decimalNumber));
String binaryNumber = "1111111111111111111111111111111";
System.out.println("Двоичное число " + binaryNumber + " равно десятичному числу " + toDecimal(binaryNumber));
}
public static String toBinary(int decimalNumber) {
if (decimalNumber <= 0)
return "";
String returned = "";
while (decimalNumber != 0) {
returned = returned + decimalNumber % 2;
decimalNumber /= 2;
}
return returned;
}
public static int toDecimal(String binaryNumber) {
if (binaryNumber == null || binaryNumber.isBlank()) {
return 0;
}
double returned = 0;
int j = binaryNumber.length();
for (int i = 0; i < binaryNumber.length(); i++) {
String s = binaryNumber.substring(j - 1, j);
returned = returned + Integer.parseInt(s) * Math.pow(2, i);
j--;
}
return (int) returned;
}
}