-
-
Notifications
You must be signed in to change notification settings - Fork 46.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fixes The Bug In Radix Tree. Issue #11316 #11385
Open
covid-in
wants to merge
18
commits into
TheAlgorithms:master
Choose a base branch
from
covid-in:turing-code
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
18 commits
Select commit
Hold shift + click to select a range
275dcfd
Fixes The Bug In Radix Tree. Issue #11316
rtron-24 87aec39
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] 394802a
Added Ruff Recommendations
rtron-24 441efe5
Merge branch 'turing-code' of https://github.com/covid-in/TheAlgorith…
rtron-24 e58ca10
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] becc449
Ruff Fixes : E501 Line too long
rtron-24 8dca3e8
Merge branch 'turing-code' of https://github.com/covid-in/TheAlgorith…
rtron-24 7b3b391
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] c9207e2
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] af76a5e
Ruff Fixes : E501 Line too long
rtron-24 3e4a386
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] ded2837
Merge branch 'turing-code' of https://github.com/covid-in/TheAlgorith…
rtron-24 298959e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] 0d53bc7
Fixes Ruff Error
rtron-24 25a8610
Merge branch 'turing-code' of https://github.com/covid-in/TheAlgorith…
rtron-24 00f1dd4
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] 66588e9
Ruff All Fixes
rtron-24 004fdf7
Merge branch 'turing-code' of https://github.com/covid-in/TheAlgorith…
rtron-24 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,5 @@ | ||
import unittest | ||
|
||
""" | ||
A Radix Tree is a data structure that represents a space-optimized | ||
trie (prefix tree) in whicheach node that is the only child is merged | ||
|
@@ -62,6 +64,11 @@ def insert(self, word: str) -> None: | |
-- A (leaf) | ||
--- A (leaf) | ||
""" | ||
## Handle the Case where word is empty by using an if branch | ||
if word == "": | ||
self.is_leaf = True | ||
return | ||
|
||
# Case 1: If the word is the prefix of the node | ||
# Solution: We set the current node as leaf | ||
if self.prefix == word and not self.is_leaf: | ||
|
@@ -191,39 +198,42 @@ def print_tree(self, height: int = 0) -> None: | |
value.print_tree(height + 1) | ||
|
||
|
||
def test_trie() -> bool: | ||
words = "banana bananas bandana band apple all beast".split() | ||
root = RadixNode() | ||
root.insert_many(words) | ||
|
||
assert all(root.find(word) for word in words) | ||
assert not root.find("bandanas") | ||
assert not root.find("apps") | ||
root.delete("all") | ||
assert not root.find("all") | ||
root.delete("banana") | ||
assert not root.find("banana") | ||
assert root.find("bananas") | ||
## write unit test for the code using unittest library with | ||
## logic similar to test_trie() function | ||
## and call it from main() | ||
|
||
return True | ||
|
||
class TestRadixNode(unittest.TestCase): | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This boilerplate adds unnecessary complexity. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Sure Will Remove it. But its the best way to do this |
||
def test_trie(self) -> None: | ||
words = "banana bananas bandana band apple all beast".split() | ||
root = RadixNode() | ||
root.insert_many(words) | ||
|
||
def pytests() -> None: | ||
assert test_trie() | ||
assert all(root.find(word) for word in words) | ||
assert not root.find("bandanas") | ||
assert not root.find("apps") | ||
root.delete("all") | ||
assert not root.find("all") | ||
root.delete("banana") | ||
assert not root.find("banana") | ||
assert root.find("bananas") | ||
|
||
def test_trie_2(self) -> None: | ||
""" | ||
now add a new test case which inserts | ||
foobbb, fooaaa, foo in the given order and checks | ||
for different assertions | ||
""" | ||
words = "foobbb fooaaa foo".split() | ||
root = RadixNode() | ||
root.insert_many(words) | ||
|
||
def main() -> None: | ||
""" | ||
>>> pytests() | ||
""" | ||
root = RadixNode() | ||
words = "banana bananas bandanas bandana band apple all beast".split() | ||
root.insert_many(words) | ||
|
||
print("Words:", words) | ||
print("Tree:") | ||
root.print_tree() | ||
assert all(root.find(word) for word in words) | ||
root.delete("foo") | ||
assert not root.find("foo") | ||
assert root.find("foobbb") | ||
assert root.find("fooaaa") | ||
|
||
|
||
if __name__ == "__main__": | ||
main() | ||
unittest.main() |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We (and the majority of the Python community) use pytest instead of unittest so all this boilerplate is not needed.
As discussed in CONTRIBUTING.md, changing both code and tests in a single pull request makes code review quite difficult.
Can you please create a separate simple pull request that adds a test that proves that
word = ""
fails?Once that is proven, we can determine how to proceed with this pull request.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It fails on subseunt recursive calls not on direct addition of "". Please check the issue it is trying to fix. I have added the same word insertions in Unit Test as well