What Will I Learn?
In this tutorial;
- You will learn the use of nested while loops.
- You will learn the use of the equalsIgnoreCase method.
- You will learn to how to compare and get the characters of the string.
- You will learn how to get the length of the string.
Requirements
- Java SE Development Kit (Not necessarily the last version) is required.
- Eclipse IDE or any similar Interated Development Enviroment (IDE) that is designed for Java programming language is required.
Difficulty
- Intermediate
Tutorial Contents
The purpose of this tutorial is to show the usage of the nested while loops in Java. A palindrome checker program is implemented for this purpose. A word that reads the same backward and forward called as palindrome. For example, "radar" is a palindrome since reading backward and forward is same. For this program, we have single java file (Palindrome_Checker.java).
The program will ask the word to the user. Therefore we need the Scanner class.
import java.util.Scanner;
In this program, two different string variables is neccessary. One of these strings is for the word which is going to be entered by the user and the other one is for the reserved string which gives another trial in program to the user. Note that "Y" is chosen as reserved string for another trial.
String word, repeat="Y";
In addition to string variables, two integer variables are also neccessary. One of these integers is for the left index position of the word and the other one is for the right index position of the word. Note that the character at the left index position and the character at the right index position will be compared in the program.
int left_index, right_index;
Now, the scanner can be defined.
Scanner scan = new Scanner(System.in);
Nested while Loops
A nested loop contains another loop inside of the outer loop. The inner loop executes for each iteration of the outer loop. In this program, the outer while loop will be to controle the number of trial. So the outer while loop will contain the whole program's single trial. In each iteration of the outer while loop a single test happens. The inner while loop will be for the index incrementation.
The equalsIgnoreCase Method
The equalsIgnoreCase method allows to ignore the lowercase and uppercase diffrences in the string. If we use this method in the outer while loop, the user can enter "Y" or "y" string to continue.
while(repeat.equalsIgnoreCase("y")) {
The program needs to ask the word to the user firstly. It can be achieved with the following code;
System.out.println("Enter the word:");
word = scan.nextLine();
Befored the comparing characters, the left index should be the index number of the first character of the string which is zero and the right index should be the index number of the last character of the string which is String.length()-1. Note that the index of the first character is 0 and last character is length of the string minus one (1).
left_index=0;
right_index=word.length()-1;
Comparing The Strings
The charAt method allows user to get the character at the given index of the string. The inner while loop compares the chars in this program. In the inner while loop, the purpose is increamenting the left index and decrementing the right index if the characters at both indexes are same and left index is smaller than the right index.
while (word.charAt(left_index)==word.charAt(right_index) && left_index<right_index) {
left_index++;
right_index--;
}
Thus, when the execution of inner while loop is finished, the string is palindrome if and only if the left index is greater than equal to right index value. The string is not a palindrome if the incremetation of left index and decrementation of right index are not enough to satisfy the right index < left index condition (In other words the entire string is not tested because the character at the right index is not equal to character at left index.) . If at the end of the inner while loop the right index < left index condition is satisfied, this means that whole string is tested and the string is palindrome.
if (right_index>left_index)
System.out.println("NOT PALINDROME");
else
System.out.println("PALIDROME");
At the end of the outer while loop, the feedback for the another trial needs to be taken with the following code.
System.out.println("Check another word (y/n)?");
repeat = scan.nextLine();
If the user enters "y" or "Y" the compiler executes outer while loop again. If the user enters other than "y" or "Y", program ends.
Results
When the program runs, the user asks the word that will be checked by the program to the user.
If you enter "palindrome" as input to the system, the system says its not palindrome as it is expected. Then, system ask "Check another word (y/n)?"
If you enter "y", the system again asks the word that will be checked by the program.
If you enter "radar" as input to the system, the system says its palindrome as it is expected
Lastly, if you enter "n" as an answer to the "Check another word (y/n)?" question, the program ends.
Code of The Program
import java.util.Scanner;
public class Palindrome_Checker {
public static void main(String[] args) {
String word, repeat="Y";
int left_index, right_index;
Scanner scan = new Scanner(System.in);
while(repeat.equalsIgnoreCase("y")) {
System.out.println("Enter the word:");
word = scan.nextLine();
left_index=0;
right_index=word.length()-1;
while (word.charAt(left_index)==word.charAt(right_index) && left_index<right_index) {
left_index++;
right_index--;
}
if (right_index>left_index)
System.out.println("NOT PALINDROME");
else
System.out.println("PALIDROME");
System.out.println("Check another word (y/n)?");
repeat = scan.nextLine();
}
}
}
Github
You can get this program here.
Curriculum
You can find my other java related tutorials in below links.
- Adding JPEG or GIF image files into the GUI in Java using Eclipse IDE
- Reading Text Files and Parsing It Using Iterators and Delimiter in Java with Eclipse IDE
- Drawing Methods in Java Applet (JApplet) Using Eclipse IDE: Drawing a Snowman
- Check Boxes (JCheckBox) and Its Listeners in a Java GUI using Eclipse IDE
- Use of Layout Managers and Tabbed Pane in Java Using Eclipse IDE
- Use of Borders in a Java GUI Using Eclipse IDE
- The Use of File Choosers in Java Using Eclipse IDE
- The Use of The Color Chooser (JColorChooser) and do - while Statement in Java Using Eclipse IDE
- The Use of Split Panes and the ListSelectionListener Interface in Java Using Eclipse IDE
- The Use of Slides and the ChangeListener Interface in Java Using Eclipse IDE
- Drawing with The paintComponent Method on the Java Panel(JPanel) Using Eclipse IDE
Posted on Utopian.io - Rewarding Open Source Contributors
I love these post.
Its sure going to help my Java coding
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
Thank you for the contribution. It has been approved.
You can contact us on Discord.
[utopian-moderator]
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
Hey @aromatheraphy I am @utopian-io. I have just upvoted you!
Achievements
Suggestions
Get Noticed!
Community-Driven Witness!
I am the first and only Steem Community-Driven Witness. Participate on Discord. Lets GROW TOGETHER!
Up-vote this comment to grow my power and help Open Source contributions like this one. Want to chat? Join me on Discord https://discord.gg/Pc8HG9x
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
Congratulations @aromatheraphy! You received a personal award!
Click here to view your Board
Do not miss the last post from @steemitboard:
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit
Congratulations @aromatheraphy! You received a personal award!
You can view your badges on your Steem Board and compare to others on the Steem Ranking
Vote for @Steemitboard as a witness to get one more award and increased upvotes!
Downvoting a post can decrease pending rewards and make it less visible. Common reasons:
Submit