Мне нужно найти минимальное значение в дереве строк, которое не является двоичным деревом поиска рекурсивно. Я попытался рассмотреть некоторые другие вопросы, подобные моим, но я не мог понять ответ.Рекурсивно найти минимальное значение в двоичном дереве в Java
Я выяснил, что мне нужно найти мин каждого из поддеревьев, затем сравнить его с корнем и вернуть минимальное значение. Но я не уверен, как это написать.
Это заголовок:
public static Object min(TreeNode t){
}
EDIT: Так что я понял, до сих пор это
public static Object min(TreeNode t){
if(t == null){
return ______;
}
else if(min(t.getLeft().compareTo(min(t.getRight()) < 0){
if(min(t.getLeft()).compareTo(t) < 0){
return min(t.getLeft());
}
}
else if(min(t.getLeft().compareTo(min(t.getRight()) > 0){
if(min(t.getRight()).compareTo(t) < 0){
return min(t.geRight());
}
}
else{
return t;
}
}
Я думаю, что я иду в правильном направлении, но я «Не знаю, что подходит в заявлении return в нулевом базовом случае. Может ли кто-нибудь помочь мне понять, что должно быть в возвращении и почему? И если я сделаю это правильно? Спасибо
Добро пожаловать в переполнение стека! Мы являемся сайтом «вопрос-ответ», а не услугой «Кодеры для найма». Пожалуйста, объясните, что вы пробовали до сих пор, и почему это не сработало. Смотрите: [Почему «Кто-нибудь может мне помочь?» не вопрос?] (http://meta.stackoverflow.com/q/284236) –
@JoeC Согласен. Тем не менее, вы должны проголосовать за закрытие в этой ситуации. – nhouser9
@GabrielOshiro Правильно, но вы должны проголосовать, чтобы закрыть в этом случае. – nhouser9