• Write programs that use loops to perform calculations and validate input
• Write programs that use if and else statements
• Write programs that display numbers formatted according to a given specification
• Format and comment source code that adheres to a given set of formatting guidelines
Scoring:
At a bare minimum, the program you submit must have the assigned source code, and your source code must compile and run without crashing.
• If you do not submit a zip file containing your source code (.java file), your score will be zero.
• If you submit source code that does not compile, your score will be zero.
• If you submit source code that roughly resembles the requirements and it compiles, but it crashes under normal operating conditions (nice input from the user), your score will be reduced by 75%.
• Deductions will be made for not meeting the usual requirements:
● Source code that is not formatted according to guidelines
● File and class names that do not meet specifications
Full credit No credit or Partial credit Use a menu to obtain user input (7 points) Your menu allows the user to choose any valid option, but does not allow any invalid integer values. There are errors in the way the menu handles valid and/or invalid input. Check if a number is prime (5 points) Your program correctly indicates whether a valid integer is prime. It only allows valid integer values from the user. There are errors in the way the menu option handles valid and/or invalid input. Factor a number
(8 points) Your program correctly factors valid integers. It only allows valid integer values from the user. There are errors in the way the menu option handles valid and/or invalid input. List prime numbers
(12 points) Your program correctly lists prime numbers when the user enters valid input. There are errors in the way the menu option handles valid and/or invalid input. Decompose a problem into methods (4 points) Your program uses short methods to break up a larger programming problem. The main method is fewer than 30 lines. You have methods that should have been broken into smaller methods. Format console output
(4 points) You formatted output as specified, including aligning prime numbers. Screen output does not match specifications.
Preliminaries:
● Review the definition of a prime number (any positive integer with exactly two factors). The first few prime numbers are 2, 3, 5, and 7. Note that 1 is not a prime number by this definition.
● Review how to format numbers to fit a particular width using printf().
Assignment requirements:
Write a program named PrimeStuff that presents the user with a menu of options related to prime numbers. The user should be able to work with prime numbers up to and including the maximum value for Java's long data type. Whenever the user enters input, make sure that their numbers are valid, using a loop to prevent them from entering invalid numbers. Match the formatting as close as possible to what is shown in the sample run. Some special notes:
● Using a Scanner that works in multiple methods: Do not create a separate Scanner object in several methods. Instead, your program should have one Scanner object that is shared by all the methods that need it. In order to do this, you will create a global Scanner object as shown. This creates it inside the class but outside of the methods:
● Factoring numbers: Factor the number into prime numbers, from smallest to largest. For example, 36 = 2 * 2 * 3 * 3. Note that if a number is prime, then it's prime factorization is itself. So, if the user wants to factor the number 83 which is prime, it would look like this: 83 = 83. Note that 1 is not prime. If the user wants to factor 1, just display 1 = 1.
● Listing prime numbers: This should let the user list as many prime numbers as she wants (up to 1000 numbers), starting at whichever positive integer she wants, with any number of numbers per row (up to 20 numbers per row). Note that if the user's starting number is a prime number, then the list should begin with that prime number. If the user's starting number is not prime, then the list should begin with the first prime after that number. When listing numbers in multiple rows, the numbers should be right-aligned over one another. See the sample run for examples.
● Validating input: You should never allow the user to try to use an illegal value. You may assume that the user will always enter an integer, but you should use a loop to make sure that the integer is always within the appropriate range. You may assume that if the user wants to list primes, she will always use a starting value that will not cause the list to exceed the maximum long value. See sample run for other limits.
● Use short methods: No method should contain more than 30 lines of code. Most methods can be written in 15 or fewer lines of code.
● Avoid code duplication: As much as possible, do not perform a calculation in more than one place. For example, there should only be one place in your code where you check to see if a number is prime.
● Submitting: Whenever you make progress (reach a new milestone), submit a draft. The class name should be PrimeStuff. It should be the only file in a folder named program10. Zip the program10 file and submit the resulting .zip file.
Sample run:
Your program should match this format as closely as possible. Note that text shown in red is there because the user typed it. You are not supposed to print those.
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 0
**** INVALID OPTION ****
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 8
**** INVALID OPTION ****
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 1
Enter a number between 1 and 9223372036854775807: -6
Enter a number between 1 and 9223372036854775807: 1001
--- 1001 is not prime.
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 2
Enter a number between 1 and 9223372036854775807: 1001
--- 1001 = 7 * 11 * 13
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 1
Enter a number between 1 and 9223372036854775807: 89
--- 89 is prime.
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 2
Enter a number between 1 and 9223372036854775807: 89
--- 89 = 89
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 2
Enter a number between 1 and 9223372036854775807: 256
--- 256 = 2 * 2 * 2 * 2 * 2 * 2 * 2 * 2
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 2
Enter a number between 1 and 9223372036854775807: 1
--- 1 = 1
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 3
Enter starting number between 1 and 9223372036854775807: 755
How many primes (1-1000): 0
How many primes (1-1000): 1001
How many primes (1-1000): 25
How many primes per row (1-20): 0
How many primes per row (1-20): 21
How many primes per row (1-20): 8
757 761 769 773 787 797 809 811
821 823 827 829 839 853 857 859
863 877 881 883 887 907 911 919
929
What would you like to do?
1) Check if a number is prime
2) Factor a number
3) List prime numbers
4) Quit
Choice: 3
Enter starting number between 1 and 9223372036854775807: 15677