From 8f195b78442ff6fc4f77b0e863345645065a7b4c Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Thu, 20 Jul 2023 22:43:16 -0600 Subject: [PATCH 01/13] Fun command line repeater --- ch03/Echo.java | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/ch03/Echo.java b/ch03/Echo.java index 07da4b0..6ad45c9 100644 --- a/ch03/Echo.java +++ b/ch03/Echo.java @@ -15,7 +15,11 @@ public static void main(String[] args) { System.out.print("Type something else: "); line = in.nextLine(); - System.out.println("You also said: " + line); + System.out.println("You then said: " + line); + + System.out.print("One more time please: "); + line = in.nextLine(); + System.out.println("I totally agree with " + line); } } From 1170db840d0c74896f6044cef0fb164639d5c9e4 Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Thu, 20 Jul 2023 22:54:17 -0600 Subject: [PATCH 02/13] Now we're talking, some similarities to python --- ch03/GuessGame.java | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 ch03/GuessGame.java diff --git a/ch03/GuessGame.java b/ch03/GuessGame.java new file mode 100644 index 0000000..2315182 --- /dev/null +++ b/ch03/GuessGame.java @@ -0,0 +1,43 @@ +import java.util.Random; +import java.util.Scanner; + +/** + * "Guess My Number" game with added fun features. + */ +public class GuessGame { + + public static void main(String[] args) { + Scanner scanner = new Scanner(System.in); + Random random = new Random(); + + System.out.println("Welcome to the Guess My Number game!"); + System.out.println("I've picked a number between 1 and 100."); + System.out.println("Try to guess it!"); + + int numberToGuess = random.nextInt(100) + 1; + int attempts = 0; + int maxAttempts = 15; + + while (attempts < maxAttempts) { + System.out.print("Enter your guess: "); + int guess = scanner.nextInt(); + attempts++; + + if (guess == numberToGuess) { + System.out.println("Congratulations! You guessed the number in " + attempts + " attempts!"); + break; + } else if (guess < numberToGuess) { + System.out.println("Too low! Try again."); + } else { + System.out.println("Too high! Try again."); + } + } + + if (attempts == maxAttempts) { + System.out.println("Oops! You've reached the maximum number of attempts."); + System.out.println("The correct number was: " + numberToGuess); + } + + scanner.close(); + } +} From cd4c4ea65e62d68e41b98e1dba7e75c3a7fe12aa Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Fri, 21 Jul 2023 09:04:25 -0600 Subject: [PATCH 03/13] Making it convert from inchs to centimeters as well --- ch03/Convert.java | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/ch03/Convert.java b/ch03/Convert.java index d31fe77..d8a0a8c 100644 --- a/ch03/Convert.java +++ b/ch03/Convert.java @@ -12,6 +12,36 @@ public static void main(String[] args) { final int IN_PER_FOOT = 12; Scanner in = new Scanner(System.in); + System.out.print("Enter 1 to convert centimeters to feet and inches\n" + + "Enter 2 to convert feet and inches to centimeters\n" + + "Your choice: "); + + int choice = in.nextInt(); + + if (choice == 1) { + System.out.print("Exactly how many cm? "); + cm = in.nextDouble(); + + if (cm < 0) { + System.out.print("Please enter a positive value for centimeters."); + } else { + inches = (int) (cm / CM_PER_INCH); + feet = inches / IN_PER_FOOT; + remainder = inches % IN_PER_FOOT; + inches = inches - (feet * IN_PER_FOOT); + System.out.printf("%.2f cm = %fd ft, %d in\n", cm, feet, inches); + } + } else if (choice == 2); { + System.out.print("Enter feet: "); + feet = in.nextInt(); + System.out.print("Enter inches: "); + inches = in.nextInt(); + + if (feet < 0 || inches < 0 || inches >= IN_PER_FOOT) { + System.out.println("Please enter valid and positive values for feet and inches."); + } + } + // prompt the user and get the value System.out.print("Exactly how many cm? "); cm = in.nextDouble(); From 623e6cd4cdca60a84467e2c195b18a4976a5a5b7 Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Fri, 21 Jul 2023 09:15:14 -0600 Subject: [PATCH 04/13] Can convert feet to centimeters and vice-versa! --- ch03/Convert.java | 19 +++++++------------ 1 file changed, 7 insertions(+), 12 deletions(-) diff --git a/ch03/Convert.java b/ch03/Convert.java index d8a0a8c..7f75210 100644 --- a/ch03/Convert.java +++ b/ch03/Convert.java @@ -29,9 +29,9 @@ public static void main(String[] args) { feet = inches / IN_PER_FOOT; remainder = inches % IN_PER_FOOT; inches = inches - (feet * IN_PER_FOOT); - System.out.printf("%.2f cm = %fd ft, %d in\n", cm, feet, inches); + System.out.printf("%.2f cm = %d ft, %d in\n", cm, feet, inches); } - } else if (choice == 2); { + } else if (choice == 2) { System.out.print("Enter feet: "); feet = in.nextInt(); System.out.print("Enter inches: "); @@ -39,19 +39,14 @@ public static void main(String[] args) { if (feet < 0 || inches < 0 || inches >= IN_PER_FOOT) { System.out.println("Please enter valid and positive values for feet and inches."); + } else { + cm = (feet * IN_PER_FOOT + inches) * CM_PER_INCH; + System.out.printf("%d ft, %d in = %.2f cm\n", feet, inches, cm); } + } else { + System.out.println("Invalid choice, please enter 1 or 2."); } - // prompt the user and get the value - System.out.print("Exactly how many cm? "); - cm = in.nextDouble(); - - // convert and output the result - inches = (int) (cm / CM_PER_INCH); - feet = inches / IN_PER_FOOT; - remainder = inches % IN_PER_FOOT; - System.out.printf("%.2f cm = %d ft, %d in\n", - cm, feet, remainder); } } From 47de60ce7ae5d272cb89ab4df24954efec863817 Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Fri, 21 Jul 2023 18:15:17 -0600 Subject: [PATCH 05/13] Consume leftover newline charachter to fix problem --- ch03/ScannerBug.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/ch03/ScannerBug.java b/ch03/ScannerBug.java index bef7834..97d3fc1 100644 --- a/ch03/ScannerBug.java +++ b/ch03/ScannerBug.java @@ -14,13 +14,14 @@ public static void main(String[] args) { name = in.nextLine(); System.out.print("What is your age? "); age = in.nextInt(); + in.nextLine(); // Consume the newline character after reading the age. System.out.printf("Hello %s, age %d\n", name, age); - in.reset(); System.out.println(); System.out.print("What is your age? "); age = in.nextInt(); + in.nextLine(); // Consume the newline character after reading the age. System.out.print("What is your name? "); name = in.nextLine(); System.out.printf("Hello %s, age %d\n", name, age); From 6a440346195e9314d50bd7993765cb77b05ff590 Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Sat, 22 Jul 2023 04:34:44 -0600 Subject: [PATCH 06/13] Convert celsius to fahrenheit, fun! --- ch03/CelsiusToFahrenheit.java | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 ch03/CelsiusToFahrenheit.java diff --git a/ch03/CelsiusToFahrenheit.java b/ch03/CelsiusToFahrenheit.java new file mode 100644 index 0000000..de63dbb --- /dev/null +++ b/ch03/CelsiusToFahrenheit.java @@ -0,0 +1,28 @@ +import java.util.Scanner; + +public class CelsiusToFahrenheit { + + public static void main(String[] args) { + // Create variables + double celsius; + double fahrenheit; + final int FREEZING_TEMP = 32; + Scanner input = new Scanner(System.in); + + // Ask for number in celsius, then save that input as the celsius variable + System.out.print("Enter a temperature in Celsius: "); + celsius = input.nextDouble(); + System.out.printf("%.1f celsius\n", celsius); + + // Conver celsius to fahrenheit + fahrenheit = (celsius * 9.0/5.0) + (FREEZING_TEMP); + + // Display result! + System.out.printf("%.1f celsius = %.1f fahrenheit\n", celsius, fahrenheit); + + + + } + + +} \ No newline at end of file From ad1d492269128a56daaba5e81abe16af58695d62 Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Sat, 22 Jul 2023 04:38:10 -0600 Subject: [PATCH 07/13] Found/fixed formatting error --- ch03/Formatting.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ch03/Formatting.java b/ch03/Formatting.java index 7beced4..9579303 100644 --- a/ch03/Formatting.java +++ b/ch03/Formatting.java @@ -11,7 +11,7 @@ public static void main(String[] args) { // formatting output System.out.print(4.0 / 3.0); - System.out.printf("Four thirds = %.3f", 4.0 / 3.0); + System.out.printf("Four thirds = %.3f\n", 4.0 / 3.0); int inch = 100; double cm = inch * CM_PER_INCH; @@ -27,7 +27,7 @@ public static void main(String[] args) { inch = (int) (cm / CM_PER_INCH); System.out.printf("%f cm = %d in\n", cm, inch); - System.out.printf("inches = %d" + inch); // error + System.out.printf("inches = %d", inch); // error was a + sign instead of a comma, fixed! } } From c50483a0e350649012ea3468f54f21be1ccba64a Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Sat, 22 Jul 2023 04:44:08 -0600 Subject: [PATCH 08/13] Found/fixed error, fun! --- ch03/Formatting.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ch03/Formatting.java b/ch03/Formatting.java index 7beced4..49d0625 100644 --- a/ch03/Formatting.java +++ b/ch03/Formatting.java @@ -27,7 +27,7 @@ public static void main(String[] args) { inch = (int) (cm / CM_PER_INCH); System.out.printf("%f cm = %d in\n", cm, inch); - System.out.printf("inches = %d" + inch); // error + System.out.printf("inches = %d", inch); // Error was a '+' sign where a comma should have been, fixed! } } From b8fe27550edaba3b6b14dd025ef75be407e3078c Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Wed, 26 Jul 2023 19:23:13 -0600 Subject: [PATCH 09/13] Practice using parameters with Java --- ch04/Date.java | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 ch04/Date.java diff --git a/ch04/Date.java b/ch04/Date.java new file mode 100644 index 0000000..3b86771 --- /dev/null +++ b/ch04/Date.java @@ -0,0 +1,27 @@ + +public class Date { + + public static void printAmerican(int date, int year, String day, String month) { + System.out.print("American format for date: "); + System.out.print(day); + System.out.print(", "); + System.out.print(month); + System.out.print(" "); + System.out.print(date); + System.out.print(", "); + System.out.println(year); + + + } + + public static void main (String[] args) { + int date = 11; + int year = 1993; + String day = "Monday"; + String month = "April"; + printAmerican(date, year, day, month); + + } + +} + From b03af23855089e0fbaae22800c3b2f9ffb3fa0ee Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Fri, 28 Jul 2023 23:46:40 -0600 Subject: [PATCH 10/13] checking for a palindrome from random letters --- ch04/IsPalindrome.java | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 ch04/IsPalindrome.java diff --git a/ch04/IsPalindrome.java b/ch04/IsPalindrome.java new file mode 100644 index 0000000..b21b5f8 --- /dev/null +++ b/ch04/IsPalindrome.java @@ -0,0 +1,35 @@ +import java.util.Random; + +public class IsPalindrome { + public static void main(String[] args) { + Random random = new Random(); + String input = generateRandomString(random, 4); + boolean isPalindrome = isSpecial(input); + System.out.println("Random String: " + input); + System.out.println("Is it a palindrome? " + isPalindrome); + } + + public static boolean isSpecial(String text) { + String tempText = alterText(text); + return text.equals(tempText); + } + + public static String alterText(String inputText) { + if (inputText == null || inputText.isEmpty()) { + return inputText; + } + return inputText.charAt(inputText.length() - 1) + + alterText(inputText.substring(0, inputText.length() - 1)); + } + + public static String generateRandomString(Random random, int length) { + String chars = "abcdefghijklmnopqrstuvwxyz"; + StringBuilder sb = new StringBuilder(length); + for (int i = 0; i < length; i++) { + int randomIndex = random.nextInt(chars.length()); + sb.append(chars.charAt(randomIndex)); + } + return sb.toString(); + } +} + From 94e0d555fadc9a2d51e7730b5eb395817af09e20 Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Fri, 28 Jul 2023 23:53:01 -0600 Subject: [PATCH 11/13] Generate random string, check if it's a palindrome --- ch04/IsPalindrome.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ch04/IsPalindrome.java b/ch04/IsPalindrome.java index b21b5f8..bcaa2c9 100644 --- a/ch04/IsPalindrome.java +++ b/ch04/IsPalindrome.java @@ -3,7 +3,7 @@ public class IsPalindrome { public static void main(String[] args) { Random random = new Random(); - String input = generateRandomString(random, 4); + String input = generateRandomString(random, 6); boolean isPalindrome = isSpecial(input); System.out.println("Random String: " + input); System.out.println("Is it a palindrome? " + isPalindrome); From fd3822a715669263e02d808358a50cd51c0a981e Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Sat, 29 Jul 2023 03:06:57 -0600 Subject: [PATCH 12/13] Merging two arrays together --- ch04/Merge.java | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 ch04/Merge.java diff --git a/ch04/Merge.java b/ch04/Merge.java new file mode 100644 index 0000000..3a77b77 --- /dev/null +++ b/ch04/Merge.java @@ -0,0 +1,36 @@ +public class Merge { + public static void main(String[] args) { + + // Test cases + int[] arr1 = { 1, 3, 5 }; + int[] arr2 = { 2, 4, 6, 8 }; + + // Call the merge function to combine the two arrays + int[] mergedArray = merge(arr1, arr2); + + // Display the merged array + System.out.println("Merged Array:"); + for (int num : mergedArray) { + System.out.print(num + " "); + } + } + + public static int[] merge(int[] a, int[] b) { + int[] result = new int[a.length + b.length]; + for (int i = 0; i < a.length; i++) { + // Place elements from array 'a' at even indices in the result array + result[2 * i] = a[i]; + + // Check if there's a corresponding element in array 'b' to place at odd index + if (i < b.length) { + result[2 * i + 1] = b[i]; + } + } + // If array b is longer than array a, add the remaining elements of b + for (int i = a.length; i < b.length; i++) { + result[2 * i] = b[i]; + } + return result; + } +} + From ac8b82d380e58a703c147a3dc6e769602c8ff200 Mon Sep 17 00:00:00 2001 From: Kyle Wehrung Date: Sun, 5 Nov 2023 00:47:41 -0600 Subject: [PATCH 13/13] added a palindrome length checker --- ch04/IsPalindrome.java | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/ch04/IsPalindrome.java b/ch04/IsPalindrome.java index bcaa2c9..04e9ea2 100644 --- a/ch04/IsPalindrome.java +++ b/ch04/IsPalindrome.java @@ -5,8 +5,10 @@ public static void main(String[] args) { Random random = new Random(); String input = generateRandomString(random, 6); boolean isPalindrome = isSpecial(input); + int longestPalindromeLength = getPalindromeLength(input); System.out.println("Random String: " + input); System.out.println("Is it a palindrome? " + isPalindrome); + System.out.println("Longest Palindromic Length: " + longestPalindromeLength); } public static boolean isSpecial(String text) { @@ -31,5 +33,29 @@ public static String generateRandomString(Random random, int length) { } return sb.toString(); } + + public static int getPalindromeLength(String text) { + String reversed = new StringBuilder(text).reverse().toString(); + int maxLength = 0; + int currentLength = 0; + + for (int i = 0; i < text.length(); i++) { + if (text.charAt(i) == reversed.charAt(i)) { + currentLength++; + if (currentLength > maxLength) { + maxLength = currentLength; + } + } else { + currentLength = 0; + } + } + return maxLength; + } + + + } + + +