Като се има предвид коренът на a Двоично дърво за търсене и цяло число к . Задачата е да се намери най-голямото число в дървото за двоично търсене, което е по-малко от или равен към k, ако такъв елемент не съществува, отпечатайте -1.
Примери:
вход:
![]()
Изход: 21
Обяснение: 19 и 25 са две най-близки числа до 21, а 19 е най-голямото число със стойност по-малка или равна на 21.
вход:![]()
Изход: 3
Обяснение: 3 и 5 са две най-близки числа до 4, а 3 е най-голямото число със стойност по-малка или равна на 4.
Съдържание
- [Наивен подход] Използване на рекурсия - O(h) време и O(h) пространство
- [Очакван подход] Използване на итерация - O(h) време и O(1) пространство
[Наивен подход] Използване на рекурсия - O(h) време и O(h) пространство
C++Идеята е да започнем от корен и сравнете стойността му с k. Ако стойността на възела е по-голяма от k, преминете към лявото поддърво. В противен случай намерете стойността на най-голямото число, по-малко от равно на k в дясно поддърво . Ако дясното поддърво върне -1 (което означава, че не съществува такава стойност), тогава се връща стойността на текущия възел. Иначе връща стойността, върната от дясно поддърво (тъй като ще бъде по-голяма от стойността на текущия възел, но по-малка от равна на k).
// C++ code to find the largest value // smaller than or equal to k using recursion #include using namespace std; class Node { public: int data; Node *left *right; Node(int val){ data = val; left = nullptr; right = nullptr; } }; // function to find max value less than k int findMaxFork(Node* root int k) { // Base cases if (root == nullptr) return -1; if (root->data == k) return k; // If root's value is smaller // try in right subtree else if (root->data < k) { int x = findMaxFork(root->right k); if (x == -1) return root->data; else return x; } // If root's data is greater // return value from left subtree. return findMaxFork(root->left k); } int main() { int k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 Node* root = new Node(5); root->left = new Node(2); root->left->left = new Node(1); root->left->right = new Node(3); root->right = new Node(12); root->right->left = new Node(9); root->right->right = new Node(21); root->right->right->left = new Node(19); root->right->right->right = new Node(25); cout << findMaxFork(root k); return 0; }
Java // Java code to find the largest value // smaller than or equal to k using recursion class Node { int data; Node left right; Node(int val) { data = val; left = null; right = null; } } class GfG { // function to find max value less than k static int findMaxFork(Node root int k) { // Base cases if (root == null) return -1; if (root.data == k) return k; // If root's value is smaller // try in right subtree else if (root.data < k) { int x = findMaxFork(root.right k); if (x == -1) return root.data; else return x; } // If root's data is greater // return value from left subtree. return findMaxFork(root.left k); } public static void main(String[] args) { int k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 Node root = new Node(5); root.left = new Node(2); root.left.left = new Node(1); root.left.right = new Node(3); root.right = new Node(12); root.right.left = new Node(9); root.right.right = new Node(21); root.right.right.left = new Node(19); root.right.right.right = new Node(25); System.out.println(findMaxFork(root k)); } }
Python # Python code to find the largest value # smaller than or equal to k using recursion class Node: def __init__(self val): self.data = val self.left = None self.right = None # function to find max value less than k def findMaxFork(root k): # Base cases if root is None: return -1 if root.data == k: return k # If root's value is smaller # try in right subtree elif root.data < k: x = findMaxFork(root.right k) if x == -1: return root.data else: return x # If root's data is greater # return value from left subtree. return findMaxFork(root.left k) if __name__ == '__main__': k = 24 # creating following BST # # 5 # / # 2 12 # / / # 1 3 9 21 # / # 19 25 root = Node(5) root.left = Node(2) root.left.left = Node(1) root.left.right = Node(3) root.right = Node(12) root.right.left = Node(9) root.right.right = Node(21) root.right.right.left = Node(19) root.right.right.right = Node(25) print(findMaxFork(root k))
C# // C# code to find the largest value // smaller than or equal to k using recursion using System; class Node { public int data; public Node left right; public Node(int val) { data = val; left = null; right = null; } } class GfG { // function to find max value less than k static int FindMaxFork(Node root int k) { // Base cases if (root == null) return -1; if (root.data == k) return k; // If root's value is smaller // try in right subtree else if (root.data < k) { int x = FindMaxFork(root.right k); if (x == -1) return root.data; else return x; } // If root's data is greater // return value from left subtree. return FindMaxFork(root.left k); } static void Main() { int k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 Node root = new Node(5); root.left = new Node(2); root.left.left = new Node(1); root.left.right = new Node(3); root.right = new Node(12); root.right.left = new Node(9); root.right.right = new Node(21); root.right.right.left = new Node(19); root.right.right.right = new Node(25); Console.WriteLine(FindMaxFork(root k)); } }
JavaScript // JavaScript code to find the largest value // smaller than or equal to k using recursion class Node { constructor(val) { this.data = val; this.left = null; this.right = null; } } // function to find max value less than k function findMaxFork(root k) { // Base cases if (root === null) return -1; if (root.data === k) return k; // If root's value is smaller // try in right subtree else if (root.data < k) { let x = findMaxFork(root.right k); if (x === -1) return root.data; else return x; } // If root's data is greater // return value from left subtree. return findMaxFork(root.left k); } let k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 let root = new Node(5); root.left = new Node(2); root.left.left = new Node(1); root.left.right = new Node(3); root.right = new Node(12); root.right.left = new Node(9); root.right.right = new Node(21); root.right.right.left = new Node(19); root.right.right.right = new Node(25); console.log(findMaxFork(root k));
Изход
21
[Очакван подход] Използване на итерация - O(h) време и O(1) пространство
C++Идеята е да започнем от корен и сравнете стойността му с к . Ако стойността на възела е <= k актуализирайте стойността на резултата до стойността на root и преминете към точно поддърво друго преместване към наляво поддърво. от итеративно прилагайки тази операция във всички възли, можем да минимизираме пространството, необходимо за рекурсия стек.
// C++ code to find the largest value // smaller than or equal to k using recursion #include using namespace std; class Node { public: int data; Node *left *right; Node(int val){ data = val; left = nullptr; right = nullptr; } }; // function to find max value less than k int findMaxFork(Node* root int k) { int result = -1; // Start from root and keep looking for larger while (root != nullptr) { // If root is smaller go to right side if (root->data <= k){ result = root->data; root = root->right; } // If root is greater go to left side else root = root->left; } return result; } int main() { int k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 Node* root = new Node(5); root->left = new Node(2); root->left->left = new Node(1); root->left->right = new Node(3); root->right = new Node(12); root->right->left = new Node(9); root->right->right = new Node(21); root->right->right->left = new Node(19); root->right->right->right = new Node(25); cout << findMaxFork(root k); return 0; }
Java // Java code to find the largest value // smaller than or equal to k using recursion class Node { int data; Node left right; Node(int val) { data = val; left = null; right = null; } } class GfG { // function to find max value less than k static int findMaxFork(Node root int k) { int result = -1; // Start from root and keep looking for larger while (root != null) { // If root is smaller go to right side if (root.data <= k) { result = root.data; root = root.right; } // If root is greater go to left side else { root = root.left; } } return result; } public static void main(String[] args) { int k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 Node root = new Node(5); root.left = new Node(2); root.left.left = new Node(1); root.left.right = new Node(3); root.right = new Node(12); root.right.left = new Node(9); root.right.right = new Node(21); root.right.right.left = new Node(19); root.right.right.right = new Node(25); System.out.println(findMaxFork(root k)); } }
Python # Python code to find the largest value # smaller than or equal to k using recursion class Node: def __init__(self val): self.data = val self.left = None self.right = None # function to find max value less than k def findMaxFork(root k): result = -1 # Start from root and keep looking for larger while root is not None: # If root is smaller go to right side if root.data <= k: result = root.data root = root.right # If root is greater go to left side else: root = root.left return result if __name__ == '__main__': k = 24 # creating following BST # # 5 # / # 2 12 # / / # 1 3 9 21 # / # 19 25 root = Node(5) root.left = Node(2) root.left.left = Node(1) root.left.right = Node(3) root.right = Node(12) root.right.left = Node(9) root.right.right = Node(21) root.right.right.left = Node(19) root.right.right.right = Node(25) print(findMaxFork(root k))
C# // C# code to find the largest value // smaller than or equal to k using recursion using System; class Node { public int data; public Node left right; public Node(int val) { data = val; left = null; right = null; } } class GfG { // function to find max value less than k static int FindMaxFork(Node root int k) { int result = -1; // Start from root and keep looking for larger while (root != null) { // If root is smaller go to right side if (root.data <= k) { result = root.data; root = root.right; } // If root is greater go to left side else { root = root.left; } } return result; } static void Main() { int k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 Node root = new Node(5); root.left = new Node(2); root.left.left = new Node(1); root.left.right = new Node(3); root.right = new Node(12); root.right.left = new Node(9); root.right.right = new Node(21); root.right.right.left = new Node(19); root.right.right.right = new Node(25); Console.WriteLine(FindMaxFork(root k)); } }
JavaScript // JavaScript code to find the largest value // smaller than or equal to k using recursion class Node { constructor(val) { this.data = val; this.left = null; this.right = null; } } // function to find max value less than k function findMaxFork(root k) { let result = -1; // Start from root and keep looking for larger while (root !== null) { // If root is smaller go to right side if (root.data <= k) { result = root.data; root = root.right; } // If root is greater go to left side else { root = root.left; } } return result; } let k = 24; // creating following BST // // 5 // / // 2 12 // / / // 1 3 9 21 // / // 19 25 let root = new Node(5); root.left = new Node(2); root.left.left = new Node(1); root.left.right = new Node(3); root.right = new Node(12); root.right.left = new Node(9); root.right.right = new Node(21); root.right.right.left = new Node(19); root.right.right.right = new Node(25); console.log(findMaxFork(root k));
Изход
21Създаване на тест