Ответ 1
Я не тестировал это, но он должен дать вам общее представление о том направлении, которое вам нужно предпринять.
Чтобы это сработало, я собираюсь взять несколько вещей о тексте TextView
:
-
TextView
состоит из строк, разделенных символом"\n"
. - Первая строка не включает оператор (+, -, * или /).
- После первой строки может быть переменное число строк в
TextView
, которое будет включать в себя оператор один и один. - Оператор всегда будет первым
Char
строки.
Сначала мы получим текст:
String input = tv1.getText().toString();
Затем разделим его на каждую строку:
String[] lines = input.split( "\n" );
Теперь нам нужно вычислить общее значение:
int total = Integer.parseInt( lines[0].trim() ); //We know this is a number.
for( int i = 1; i < lines.length(); i++ ) {
total = calculate( lines[i].trim(), total );
}
Метод вычисления должен выглядеть так, считая, что мы знаем, что первая Char
строки - это оператор:
private int calculate( String input, int total ) {
switch( input.charAt( 0 ) )
case '+':
return total + Integer.parseInt( input.substring( 1, input.length() );
case '-':
return total - Integer.parseInt( input.substring( 1, input.length() );
case '*':
return total * Integer.parseInt( input.substring( 1, input.length() );
case '/':
return total / Integer.parseInt( input.substring( 1, input.length() );
}
ИЗМЕНИТЬ
Итак, выше, как указано в комментарии ниже, выполняется "слева направо", игнорируя нормальный порядок (+ и/до + и -).
Ниже приведен правильный расчет:
String input = tv1.getText().toString();
input = input.replace( "\n", "" );
input = input.replace( " ", "" );
int total = getValue( input );
Метод getValue
является рекурсивным методом, и он должен выглядеть следующим образом:
private int getValue( String line ) {
int value = 0;
if( line.contains( "+" ) ) {
String[] lines = line.split( "\\+" );
value += getValue( lines[0] );
for( int i = 1; i < lines.length; i++ )
value += getValue( lines[i] );
return value;
}
if( line.contains( "-" ) ) {
String[] lines = line.split( "\\-" );
value += getValue( lines[0] );
for( int i = 1; i < lines.length; i++ )
value -= getValue( lines[i] );
return value;
}
if( line.contains( "*" ) ) {
String[] lines = line.split( "\\*" );
value += getValue( lines[0] );
for( int i = 1; i < lines.length; i++ )
value *= getValue( lines[i] );
return value;
}
if( line.contains( "/" ) ) {
String[] lines = line.split( "\\/" );
value += getValue( lines[0] );
for( int i = 1; i < lines.length; i++ )
value /= getValue( lines[i] );
return value;
}
return Integer.parseInt( line );
}
Особые случаи, с которыми не справляется рекурсивный метод:
- Если первое число отрицательно, например. -3 + 5 * 8.
- Двойные операторы, например. 3 * -6 или 5/-4.
Также тот факт, что мы используем Integers
, может дать некоторые "нечетные" результаты в некоторых случаях, например. 5/3 = 1.