Name: Atharva Bansal
Class : 12 Section : A
Roll No: 23
Computer Science Practical
1
Question 1:
Write a program to input a natural number ‘n’ between 1 to 10000.Print
it in words as well roman numerals.
Algorithm:
1. Start
2. Input: Read a natural number n from the user.
3. Validation: Check if n is between 1 and 10000 inclusive:
-If n is not in this range, print "Invalid Input" and terminate.
4. Convert to Roman Numeral:
-Define arrays for Roman numeral symbols for units, tens, hundreds,
thousands, and ten-thousands.
-Extract the digits from n for each place value (units, tens, hundreds,
thousands, ten-thousands).
-Use the arrays to get the Roman numeral symbols for each digit.
-Concatenate the symbols to form the full Roman numeral
representation.
-Convert to Words:
5. Define arrays for word representations of units, tens, hundreds,
thousands, and ten-thousands.
-Extract the digits from n for each place value.
-If the tens digit is 1, use a special array for numbers 10 to 19.
-For other tens digits, use the appropriate array for tens and concatenate
with the unit's word.
-Concatenate the words to form the full word representation.
6. Output: Print the number n, its Roman numeral, and its word
representation.
7. End.
2
Source Code:
import java.util.Scanner;
public class Question1 {
// Method to convert a number to Roman numeral
public static String Roman(int num) {
// Arrays containing Roman numeral symbols for each place value
String[] tenthousands = {"", "X\u0304"}; // 10000 and 20000
String[] thousands = {"", "M", "MM", "MMM", "MV\u0304", "V\
u0304", "V\u0304M", "V\u0304MM", "V\u0304MMM", "MX\u0304"};
String[] hundreds = {"", "C", "CC", "CCC", "CD", "D", "DC", "DCC",
"DCCC", "CM"};
String[] tens = {"", "X", "XX", "XXX", "XL", "L", "LX", "LXX",
"LXXX", "XC"};
String[] ones = {"", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"};
// Extract each digit from the number
int o = num % 10; // Ones place (units)
int t = (num / 10) % 10; // Tens place
int h = (num / 100) % 10; // Hundreds place
int th = (num / 1000) % 10; // Thousands place
int tth = (num / 10000) % 10; // Ten-thousands place
// Construct the Roman numeral by concatenating the symbols for each
place value
String rom = tenthousands[tth] + thousands[th] + hundreds[h] + tens[t] +
ones[o];
return rom;
}
3
// Method to convert a number to words
public static String Words(int num) {
// Arrays containing word representations for each place value
String[] tenthousands = {"", "Ten Thousand"}; // 10000 and 20000
String[] thousands = {"", "One Thousand", "Two Thousand", "Three
Thousand", "Four Thousand", "Five Thousand", "Six Thousand", "Seven
Thousand", "Eight Thousand", "Nine Thousand"};
String[] hundreds = {"", "One Hundred", "Two Hundred", "Three
Hundred", "Four Hundred", "Five Hundred", "Six Hundred", "Seven
Hundred", "Eight Hundred", "Nine Hundred"};
String[] tens1 = {"Ten", "Eleven", "Twelve", "Thirteen", "Fourteen",
"Fifteen", "Sixteen", "Seventeen", "Eighteen", "Nineteen"};
String[] tens2 = {"", "", "Twenty", "Thirty", "Forty", "Fifty", "Sixty",
"Seventy", "Eighty", "Ninety"};
String[] ones = {"", "One", "Two", "Three", "Four", "Five", "Six",
"Seven", "Eight", "Nine"};
// Extract each digit from the number
int o = num % 10; // Ones place (units)
int t = (num / 10) % 10; // Tens place
int h = (num / 100) % 10; // Hundreds place
int th = (num / 1000) % 10; // Thousands place
int tth = (num / 10000) % 10; // Ten-thousands place
String wrd = "";
// Convert number to words
if (t == 1) {
// For numbers 10-19
4
wrd = tenthousands[tth] + " " + thousands[th] + " " + hundreds[h] + "
" + tens1[o];
} else {
// For numbers 20 and above
wrd = tenthousands[tth] + " " + thousands[th] + " " + hundreds[h] + "
" + tens2[t] + " " + ones[o];
}
return wrd.trim(); // Return the final word representation, trimming any
extra spaces
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
// Prompt user for input
System.out.println("Enter a natural number between 1 to 10000: ");
int n = sc.nextInt();
// Validate the input number
if (n < 1 || n > 10000) {
System.out.println("Invalid Input");
System.exit(0); // Exit the program if input is invalid
}
// Output the number in words and Roman numerals
System.out.println(n + " in words: " + Words(n));
System.out.println(n + " in Roman numerals: " + Roman(n));
}
}
5
Variable Description:
Variable Datatype Description
Tenthousands,thousands,tens1 String[] To help in converting
Hunreds,tens2,ones the number to words
in words and roman
numerals
num,n int Used to store the input
by user
o,t,h,th,tth int To store all digits of n
rom String To store converted
roman numeral
wrd String To store the converted
word
Sample:
Input: Enter a natural number between 1 to 10000:
1234
Output:1234 in words: One Thousand Two Hundred Thirty Four
1234 in Roman numerals: MCCXXXIV
6
Question 2:
Caeser Cipher is an encryption technique which is implemented by ROT
13 i.e. rotate by 13 places. It is a simple letter substitution that replaces a
with the letter 13 places after it.
Write a program to convert a text to the caeser cipher word.
Algorithm:
1. Start
2. Input: Read a string from the user.
3. Convert to Uppercase: Convert the entire input string to uppercase.
4. Initialize Variables:
5. Create an empty string ans to store the transformed result.
6. Tokenize the String:
7. Use a tokenizer to split the string into words based on delimiters (space,
?, !, and .).
8. Process Each Token:
9. For each token (word):
a. Process Each Character:
i. For each character in the word:
1. Apply ROT13 Cipher:
a. Rotate the character 13 positions forward in the
alphabet:
i. Increment the character’s ASCII value.
ii. If the ASCII value goes past Z, wrap
around to A.
2. Append Transformed Character: Add the transformed
character to ans.
b. Append Space: After processing each word, add a space to ans.
7
10. Output: Print the final transformed string ans.
11. End.
Source Code:
import java.util.*;
class Question2
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
System.out.println("Enter the String to be converted:");
String str = sc.nextLine();// Convert the entire string to uppercase
str = str.toUpperCase();
// Initialize an empty string to store the final result
String ans = "";
// Create a StringTokenizer to split the string
StringTokenizer st = new StringTokenizer(str, " ?!.");
// Process each token (word) from the tokenizer
while (st.hasMoreTokens())
{
// Get the next token (word)
String word = st.nextToken();
// Process each character in the current word
for (int x = 0; x < word.length(); x++)
{
// Get the current character
8
char ch = word.charAt(x);
int t = 0;
// Apply the ROT13 cipher by rotating the character 13 positions
forward
while (t != 13) {
ch = (char)(ch + 1); // Increment character
// Wrap around if the character goes past 'Z'
if ((int)ch > 90) {
ch = (char)65; // Reset to 'A'
}
t++;
}
ans += ch;
}
// Append a space after each processed word
ans += " ";
}
// Print the final transformed string
System.out.println(ans);
}
}
9
Variable Description:
Variable Datatype Description
str String Input by the user
ans String To store the converted
String
word String To store each word of
str
ch char To store each character
of each word and
convert it
t int To increase the
character by 13
Sample:
Input: Enter the String to be converted:
HELLO WORLD
Output: URYYB JBEYQ
10
Question 3:
Write a program to accept a date in string format(dd/mm/yyyy) and
accept the name of day on 1st January of the corresponding year. Find
the day for the given date.
Algorithm:
1. Start
2. Input Date:
3. Read the date in dd/mm/yyyy format from the user.
4. Tokenize the input date string by the delimiter /.
5. Parse the day (d), month (m), and year (y) from the tokenized string.
6. Input Day of January 1:
7. Read the day of the week for January 1st of the given year from the user.
8. Initialize Arrays:
9. Define an array mon with month names: January, February, ...,
December.
10. Define an array week with the days of the week: Monday, Tuesday, ...,
Sunday.
11. Define an array noOfdays with the number of days in each month:
a. For February, use 29 days if the year is a leap year (y % 4 == 0),
otherwise 28 days.
b. Other months have their respective number of days.
12. Find Day Index for January 1:
13. Initialize t to zero.
14. Loop through the week array to find the index of the input day of the
week and set t to this index.
15. Calculate Day of the Week for Given Date:
11
16. Initialize dn to 1 (starting day of the month) and month to 1 (January).
17. While dn is not equal to the input day d or month is not equal to the
input month m:
a. Increment dn to move to the next day.
b. Increment t to move to the next day of the week.
c. If dn exceeds the number of days in the current month
(noOfdays[month - 1]):
i. Increment month to move to the next month.
ii. Reset dn to 1 (first day of the new month).
d. If t exceeds 6 (Sunday), reset t to 0 (Monday).
18. Output Result:
19. Print the day of the week for the specified date, using the week array
and the final value of t.
20. End.
Source Code:
12
import java.util.*;
class Question3
{
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
System.out.println("Enter date in dd/mm/yyyy");
String date = sc.next();
// Tokenize the date string by "/"
StringTokenizer st = new StringTokenizer(date, "/");
// Parse the day, month, and year from the tokenized date string
int d = Integer.parseInt(st.nextToken());
int m = Integer.parseInt(st.nextToken());
int y = Integer.parseInt(st.nextToken());
// Prompt user to enter the day of the week on January 1 of the given
year
System.out.println("Enter day on January 1");
String dayon1 = sc.next();
String mon[] = {"January", "February", "March", "April", "May",
"June", "July", "August", "September", "October", "November",
"December"};
String week[] = {"Monday", "Tuesday", "Wednesday", "Thursday",
"Friday", "Saturday", "Sunday"};
int noOfdays[] = {31, y % 4 == 0 ? 29 : 28, 31, 30, 31, 30, 31, 31, 30,
31, 30, 31};
int dn = 1; // Start from the first day of the month
13
int t = 0;
// Find the index of the given day of the week for January 1
for (int x = 0; x < week.length; x++)
{
if (dayon1.equalsIgnoreCase(week[x]))
{
t = x; // Day index in the week
break;
}
}
int month = 1;
// Calculate the day of the week for the given date
while (dn != d || month != m)
{
dn++;
t++;
if (dn > noOfdays[month - 1])
{
month++;
dn = 1; // Reset day to the first of the new month
}
if (t == 7)
t = 0;
}
14
// Output the day of the week for the given date
System.out.println("Day on " + d + " " + mon[m - 1] + " : " + week[t]);
}
}
Variable Description:
Variable Datatype Description
date String To input the date in
dd/mm/yyyy format
d,m,y int To split date in
date ,month and year
dayon1 String Store the day on 1st
January
mon String[] To store names of all
months
week String[] To store name of every
day of the week
noOfdays int[] To store no. of days in
each month
dn int To store total no. of
days passed
t int To store index of each
day of week
month int To store the index of
the current month
Sample:
15
Input:
Enter date in dd/mm/yyyy
05/01/2024
Enter day on January 1
Tuesday
Output:
Day on 5 January : Saturday
16