Introduction

Hello, and welcome! Are you ready to elevate your string manipulation skills in Java? Today, we'll delve into a task that bolsters your comprehension of strings and enhances your creativity. The task involves splitting a string into words and then reversing each word as if reflected in a mirror. Does that sound interesting? Let's get started!

Task Statement and Description

You're tasked with considering a string filled with words and writing a Java function that accepts this string. The function should reverse the character order of each word and form a new string consisting of these reversed words.

Here's what you need to keep in mind:

  • The input string will contain between 1 and 100 words.
  • Each word in the string is a sequence of characters separated by whitespace.
  • The characters can range from a to z, A to Z, 0 to 9, or even an underscore _.
  • The provided string will neither start nor end with a space, and double spaces won't be present either.
  • After reversing the words, your program should output a single string with the reversed words preserving their original order.

Example

Consider the input string "Hello neat java_lovers_123".

The function works as follows:

  • Hello becomes olleH
  • neat becomes taen
  • java_lovers_123 becomes 321_srevol_avaj

Afterward, it forms a single string with these reversed words, producing "olleH taen 321_srevol_avaj".

Therefore, if you call reverseWords("Hello neat java_lovers_123"), the function should return "olleH taen 321_srevol_avaj".

Let's begin breaking this down!

Step-by-Step Solution Building: Step 1

Our first task is to separate the words in the sentence. In Java, the split() method of the String class allows us to achieve this easily. The delimiter you'll use in the split() method is a regular expression for a single space " ". Here is a sample code to illustrate this:

Note that " " as the regex delimiter ensures that the string is split at each space, effectively separating the words.

Step-by-Step Solution Building: Step 2

Next, we need to reverse each word separated in the previous step. In Java, we can use the StringBuilder class, which provides a reverse() method to do this. Let's add these lines to our existing code:

Step-by-Step Solution Building: Step 3

Finally, we need to consolidate these reversed words into a single string, separated by spaces. We can achieve this using the StringBuilder class in Java. Here's how we do that:

First, we append the first word to the StringBuilder, then append a space followed by the next word in a loop. This way, we add all words while preserving the format. The resulting string can be obtained by calling the toString() method on the StringBuilder.

Final Solution

It remains for us to combine the code from the steps together in a function reverseWords and call it from the main method to test.

Lesson Summary

Well done! By completing this lesson, you've sharpened your proficiency in manipulating strings in Java. You've improved especially in reversing the order of characters in a word. I hope you're feeling confident and excited about your Java skills. Remember, mastering these skills requires frequent practice. Therefore, take some time to explore related problems and practice what you’ve learned. Enjoy the journey of learning!

Sign up
Join the 1M+ learners on CodeSignal
Be a part of our community of 1M+ users who develop and demonstrate their skills on CodeSignal