Assignment 1 – Factorials in terms of Prime Numbers
60-141 – Introduction to Programming II
The factorial of a number N (written N!) is defined as the product of all the integers from 1 to N. It is often defined recursively as follows:
0!=1 (By definition)
N!= N ×(N −1)!
[NOTE: Factorial of a negative number is undefined, and is not permitted.]
Factorials grow very rapidly — 5! = 120, 10! = 3,628,800. One way of specifying such large numbers is by specifying the number of times each prime number occurs in it. Thus 825 could be specified as (0 1 2 0 1) (or, (2,0) (3,1) (5,2) (7,0) (11,1)) meaning no twos, 1 three, 2 fives, no sevens and 1 eleven. For this assignment, we will follow the notation as: 825 = (2^0)*(3^1)*(5^2)*(7^0)*(11^1)
[NOTE: Although it is not required, students are advised to try to compute N! using simple integer multiplication in order to determine the largest N for which the computer does not produce an overflow. This optional exercise will underscore why this assignment is relevant in numeric computation.]
Your task is to:
Write a complete, well documented C program that will read in an integer number N (limited by 2 < N <100) and write out its factorial in terms of the numbers of its prime factors, using the output notation explained above.
Requirements and Hints:
1. You do not have to actually calculate the factorial of any number to solve this problem.
2. Given the first prime number 2, your program logic will:
a. Determine how many times this prime number will occur in N!.
b. Then the program will determine what is the next prime number, and go back to step a.
c. Steps a. and b. will continue until all the prime numbers < N are evaluated.
3. For example: 4! = 2X3X4, where the prime 2 occurs three times (2X4) = (2X2X2) = (2^3), and the prime 3 occurs only one time, (3^1). So 4! = (2^3)*(3^1). Likewise, 5! = (2^3)*(3^1)*(5^1).
4. Your program should implement at least the following 3 functions:
a. find_prime_count(), that will count the number of a given prime in N!.
b. find_next_prime(), that, given a prime number, will determine the next prime number.
c. is_prime(), that will determine whether a number is a prime number or not.
Input:
You have to use input redirection technique to enter inputs from a text file.
Example: a.out < input.txt
The input file will consist of a series of lines, each line containing a single integer N. The file will
be terminated by a line consisting of a single 0.
Output (you must follow the following format!):
Output will consist of a series of blocks of lines, one block for each line of the input. Each block
will start with the number N, right justified in a field of width 3, and the characters `!’, space, `=’
and 2 spaces.
This will be followed by a list of pairs of numbers in parenthesis, such as (x^y), separated by *,
where x is a prime number and y is the number of times the prime number x occurs in N!.
These should be right justified in variable width fields (shown below) and each line (except the
last of a block, which may be shorter) should contain 9 pairs of numbers. Any lines after the first
should be indented.
Follow the layout of the example shown below exactly.
Sample input file:
5
53
100
0
Sample output (you must follow the output format):
5! = (2^3)*(3^1)*(5^1)
53! = (2^49)*(3^23)*(5^12)*(7^8)*(11^4)*(13^4)*(17^3)*(19^2)*(23^2)
*(29^1)*(31^1)*(37^1)*(41^1)*(43^1)*(47^1)*(53^1)
100! = (2^97)*(3^48)*(5^24)*(7^16)*(11^9)*(13^7)*(17^5)*(19^5)*(23^4)
*(29^3)*(31^3)*(37^2)*(41^2)*(43^2)*(47^2)*(53^1)*(59^1)*(61^1)
*(67^1)*(71^1)*(73^1)*(79^1)*(83^1)*(89^1)*(97^1)
REQUIREMENTS:
– Write and document a complete C program that is capable of satisfying the requirements of this
assignment problem.
To create a script file (one that logs your compilation steps and your output in a text file):
1. script assign1.txt
2. cat assign1.c
3. cat input.txt
4. cc assign1.c
5. a.out < input.txt
6. ls -l
7. exit
Answer:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 | /* Title: Assignment #1: Factorials in terms of prime numbers Objective: This program will read in an integer number and write out its factorial in terms of the numbers of its prime factors. */ //C-Preprocessor Directives # include <stdio.h> //Function Prototypes int find_prime_count(int primeNumber, int num); int find_next_prime(int num); int is_prime(int num); /* Objective: This function is used to count number of times the prime number occurs in the entered number "num". Input:prime number and number of occurrence of that number. Output: Return number of times the prime number occurs. */ int find_prime_count(int primeNumber, int num){ int counter = 0; while (num % primeNumber == 0){ counter++; num /= primeNumber; } return counter; } /* Objective: This function is used to find the next prime number. Input:Non negative integer (num >0) . Output: Return prime Number. */ int find_next_prime(int num){ int nextPrime; //Choose the base case (num=1) if (num == 1) return num + 1; //Choose the base case (num=2) if (num == 2) return num + 1; //choose the next odd num if (num % 2 == 0) nextPrime += num ; else nextPrime = num + 2; //while loop to find next prime number and calling the"is_prime" function to check the next prime number while ( !is_prime (nextPrime) ) //Add 2 nextPrime += 2; return nextPrime; } /* Objective: This function is used to check if the entered number "num" is prime number(return 1) or not prime number (return 0). Input:Non negative integer (num >0) . Output: Return 1 if num is prime number. */ int is_prime(int num){ //Check if the passed number is 2 if (num == 2 ) return 1; //Check if the passed number is 3 if (num == 3 ) return 1; //Check if we can divide the passed number by 2 with no remainder then it is not prime(return 0) if (num % 2 == 0) return 0; //initializing the first prime and odd number after the 2 int k = 3; //Check if the number can be divided by 3 with no remainder while (num % k != 0){ //The passed number to this function is prime number if (k * k > num) //return "it is a prime number" and use the value for the next calculation return 1; //Add 2 and check if the next odd number is prime k +=2; } //No more to check(return 0) return 0; } //Main function int main(){ //Declare variables int num,multiple; //Prompt the user to enter a number printf( "\n\nPlease enter a number, or 0 to QUIT\n" ); //Store the value in variable num scanf( "%d" ,&num); //Check if the entered number is positive between 2 to 100 if (num>=2 && num<=100){ //Main do while loop do { //Display the number "num" in a field of width 3 and the char "!" ,"space", "=" ,"2 spaces" printf( "%3d! = " , num); //start with the smallest prime Number which is "2" int primeNumber = 2, j = 0; /*While loop to check if 2 still less than or equal to the entered number and use the function "find_prime_count" to count how many times the prime number is repeating*/ while (primeNumber <= num){ //initializing "howMany" int howMany = 0; //for loop to find the prime count using "find_prime_count" function for (multiple = 1; multiple <= num; multiple++){ //Check if the prime number is less than the multiple factor for a specific prime number if (primeNumber <= multiple) //Accumulator howMany += find_prime_count(primeNumber, multiple) ; } // Check if the number is not 2 if (primeNumber != 2) //Display any prime Number other than 2 and how many times it appears with the specified format printf( "*(%d^%d)" , primeNumber, howMany); //if the number is 2 else //Display num 2 and how many times it appears with the specified format printf( "(%d^%d)" , primeNumber, howMany); //Go to next prime Number by calling the "find_next_prime" function primeNumber = find_next_prime(primeNumber); //increment j by 1(which is used to count how many prime numbers we have in one line) j++; //Go to next line after displaying 9 prime Numbers in one line if (j % 9 == 0) //after displaying 9 prime numbers in one line go to next line printf( "\n " ); } //end while loop //Prompt the user to enter the next number printf( "\n\nPlease enter the next number , or 0 to QUIT\n" ); //Accept the next number and store it in the variable num scanf( "%d" ,&num); } while (num !=0); //End of do while loop //Prompt to the user if the entered number is 0 to quit the program printf( "\nThank you for using this program. Please come back a gain \n" ); } //prompt to the user if the number entered less than 2 or greater than 100 else { printf( "\nThank you for using this program <img draggable=" false " class=" emoji " alt="
" src=" https: //s.w.org/images/core/emoji/11/svg/1f642.svg"> \n"); } } |
Leave a reply