Enhance Upper.java – Optimized, Safe, and Clean Implementation of String Uppercase Conversion#6888
Enhance Upper.java – Optimized, Safe, and Clean Implementation of String Uppercase Conversion#6888saurabh22111999 wants to merge 2 commits intoTheAlgorithms:masterfrom
Conversation
saurabh22111999
left a comment
There was a problem hiding this comment.
“Enhanced Upper.java by fixing the typo in the exception message, adding null and empty checks, optimizing for strings that are already uppercase, and improving code readability and documentation. All changes are tested using assertions to ensure correctness.
saurabh22111999
left a comment
There was a problem hiding this comment.
“I noticed that the current implementation does not include JUnit test cases for automated verification. Please consider adding a UpperTest.java with proper unit tests to validate all edge cases (null, empty, already uppercase, special characters). This will ensure your contribution meets TheAlgorithms repository standards.”
Codecov Report❌ Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## master #6888 +/- ##
============================================
- Coverage 77.96% 77.94% -0.02%
- Complexity 6431 6433 +2
============================================
Files 736 737 +1
Lines 21476 21493 +17
Branches 4204 4208 +4
============================================
+ Hits 16744 16753 +9
- Misses 4060 4065 +5
- Partials 672 675 +3 ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
|
|
This pull request has been automatically closed because its workflows or checks failed and it has been inactive for more than 14 days. Please fix the workflows and reopen if you'd like to continue. Merging from main/master alone does not count as activity. |
This pull request improves the Upper class in the com.thealgorithms.strings package by refining its toUpperCase() method.
The updated version ensures robust null handling, optimized performance, and cleaner structure consistent with Java best practices.
🔍 Summary of Enhancements
Type Description
🧠 Logic Improvement Added null and empty string checks at the beginning to prevent unexpected exceptions.
⚙️ Optimization Added a pre-check (hasLower) to skip conversion if no lowercase characters exist, improving efficiency for already uppercase strings.
💬 Documentation Improved JavaDoc comments for clarity and completeness.
🧩 Code Readability Improved indentation, spacing, and consistent code style.
🧹 Safety Fix Prevented potential NullPointerException by checking input before conversion.
✍️ Typo Fix Corrected “connot” → “cannot” in the exception message.
🧪 Validation Ensured correctness using assertions that compare results with Java’s built-in String.toUpperCase() method.
✅ Code Behavior
Input: "abc123XYZ"
Output: "ABC123XYZ"
Edge Cases:
null → Throws IllegalArgumentException
"" → Returns empty string ("")
"123!@#" → Returns same string (no alphabetic characters)
"HELLO" → Returns same string (optimized skip logic)
🎯 Benefits
Safer and faster implementation.
Adheres to clean code principles.
Ready for use in production-grade algorithms repository.
🔖 File Modified
src/main/java/com/thealgorithms/strings/Upper.java
📋 Checklist
I have read CONTRIBUTING.md
.
This pull request is all my own work -- I have not plagiarized it.
All filenames are in PascalCase.
All functions and variable names follow Java naming conventions.
All new algorithms have a URL in their comments that points to Wikipedia or other similar explanations.
All new code is formatted with clang-format -i --style=file path/to/your/file.java.