#java #if
Можно ли улучшить(упростить) данную конструкцию тернарным оператором? if (isLeftLetter && isRightLetter) { swap(chars, leftElementIndex, rightElementIndex); leftElementIndex++; rightElementIndex--; } else { if (!isLeftLetter) { leftElementIndex++; } if (!isRightLetter) { rightElementIndex--; } }
Ответы
Ответ 1
Я бы написал так: if (isLeftLetter && isRightLetter) { swap(chars, leftElementIndex, rightElementIndex); leftElementIndex++; rightElementIndex--; } else { leftElementIndex=(!isLeftLetter) ? leftElementIndex+1 : leftElementIdex; rightElementIndex=(!isRightLetter) ? rightElementIndex+1 : rightElementIdex; } Update Тернарный оператор удобно использовать для однострочных присвоений, а ля: var=(condition) ? expression1 : expression2; в остальных вариантах, я лично не рекомендую (верю, что некоторые не согласятся)Ответ 2
(isLeftLetter && isRightLetter) ? (swap(chars, leftElementIndex, rightElementIndex), leftElementIndex++, rightElementIndex--) : ( (!isLeftLetter) ? leftElementIndex++ : leftElementIndex, (!isRightLetter) ? rightElementIndex-- : rightElementIndex ); Все же нежелательно использовать данную конструкцию. Как видите читаемость стала лишь сложнее. Но если это Ваш личный проект и Вы сами его поймете, то дело Ваше.
Комментариев нет:
Отправить комментарий