Enhance Upper.java – Optimized, Safe, and Clean Implementation of String Uppercase Conversion #6888
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.
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.