February 21, 2012
TO ALL 2nd YEAR BSIT STUDENTS
IT 14 - Programming Exercises in Recursion
1. Write a recursive method that takes as a parameter a nonnegative integer and generates the following pattern of stars. If the nonnegative integer is 4, then the pattern generated is:
****
***
**
*
*
**
***
****
Also, write a program that prompts the user to enter the number of lines in the pattern and uses the recursive method to generate the pattern. For example, specifying 4 as the number of lines generates the above pattern.
2. Write a recursive method that finds and returns the sum of the elements of an int array. Also, write a program to test your method.
3. A palindrome is a string that reads the same both forwards and backwards. For example the string “madam” is a palindrome. Write a program that uses a recursive method to check whether a string is a palindrome. Your program must contain a value-returning recursive method that returns true if the string is a palindrome, and false otherwise. Use the appropriate parameters.
4. Write a program that uses a recursive method to print a string backwards. Your program must contain a recursive method that prints the string backwards. Use the appropriate parameters.
5. Write a recursive method, reverseDigits, which takes an integer as a parameter and returns the number with the digits reversed. Also, write a program to test your method.
6. Write a recursive method, power, which takes as parameters two integers x and y such that x is nonzero and returns xy. You can use the following recursive definition to calculate xy. If y≥ 0,
1 if y=0
power(x,y) = x if y=1
x*power(x,y-1) if y>1
If y<0,
Also, write a program to test your method.
7. (Greatest Common Divisor) Given two integers x and y, the following recursive definition determines the greatest common divisor of x and y, written gcd(x,y):
x if y = 0
gcd(x, y) =
gcd(y,x%y) if y≠ 0
Note: In this definition, % is the mod operator.
Write a recursive method, gcd, which takes as parameters two integers and returns the greatest common divisor of the numbers. Also, write a program to test your method.
8. (Converting a Number from Binary to Decimal) The language of a computer, called machine language, is a sequence of 0s and 1s. When you press the key A on the keyboard, 01000001 is stored in the computer. Also, the collating sequence of A in the Unicode character set is 65. In fact, the binary representation of A is 01000001 and the decimal representation of A is 65.
The numbering system we use is called the decimal system, or base 10 system. The numbering system that the computer uses is called the binary system, or base 2 system. The purpose of this is to write a program to convert a number from base 2 to base 10.
To convert a number from base 2 to base 10, we first find the weight of each bit in the binary number. The weight of each bit in the binary number is assigned from right to left. The weight of the rightmost bit is 0. The weight of the bit immediately to the left of the rightmost bit is 1; the weight of the bit immediately to the left of it is 2, and so on. Consider the binary number 1001101. The weight of each bit is as follows:
weight 6 5 4 3 2 1 0
1 0 0 1 1 0 1
We use the weight of each bit to find the equivalent decimal number. For each bit, we multiply the bit by 2 to the power of its weight, and then we add all of the numbers. For the above binary number, the equivalent decimal number is
1 * 26 + 0 * 25 + 0 * 24 + 1 * 23 + 1 * 22 + 0 * 21 + 1 * 20
= 64 + 0 + 0 + 8 + 4 + 0 + 1
= 77
To write a program that converts a binary number into its equivalent decimal number, we note two things: (1) the weight of each bit in the binary number must be known, and (2) the weight is assigned from right to left. Because we do not know in advance how many bits are in the binary number, we must process the bits from right to left. After processing a bit, we can add 1 to its weight, giving the weight of the bit immediately to the left to it. Also, each bit must be extracted from the binary number and multiplied by 2 to the power of its weight. To extract a bit, you can use the mod operator. Write a method that converts a binary number into an equivalent decimal number.
Moreover, write a program and test your method for the following values: 11000101, 10101010, 11111111, 10000000, and 1111100000.
9. Two more number systems, octal (base 8) and hexadecimal (base 16), are of interest to computer scientists. In fact, in Java, you can instruct the computer to store a number in octal or hexadecimal.
The digits in the octal umber system are 0, 1, 2, 3, 4, 5, 6, and 7. The digits in the hexadecimal number system are 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, and F. So A in hexadecimal is 10 in decimal, B in hexadecimal is 11 in decimal, and so on.
The algorithm to convert a positive decimal number into an equivalent number in octal (or hexadecimal) is the same for binary numbers. Here we divide the decimal number by 8 (for octal) and by 16 (for hexadecimal). Suppose ab represents the number a to the base b. For example, 7510 means 75 to the base 10 (that is, decimal), and 8316 means 83 to the base 16 (that is, hexadecimal). Then
75310 = 13618
75310 = 2F116
The method of converting a decimal number to base 2, or 8, or 16 can be extended to any arbitrary base. Suppose you want to convert a decimal number n into an equivalent number in base b, where b is between 2 and 36, you then divide the decimal number n by b as in the algorithm for converting decimal to binary.
Note that the digits in, say, base 20 are 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F, G, H, I, and J.
Write a program that uses a recursive method to convert a number in decimal to a given base b, where b is between 2 and 36. Your program should prompt the user to enter the number in decimal and in the desired base.
Test your program on the following data:
9098 and base 20
692 and base 2
753 and base 16
Note:
· This programming exercise must be done individually.
· You are required to solve at least 5 problems among the given problems herein.The more problems correctly solved, the higher points you can acquire.
· Write the problems, the corresponding recursive definitions (define the base case(s) and the recursive case of the algorithm) and the source code for each problem you have chosen on a long bond paper.
· Secure a soft copy of your program for presentation purposes.
· Chosen student must present his/her solutions during class lecture and/or laboratory time.
· Students having the same solutions in a problem shall suffer a corresponding deduction.
Prepared by:
LEMUEL L. APA
Instructor