Advertisements
Advertisements
A super class EmpSal has been defined to store the details of an employee. Defie a subclass (overtime to compute the total salary of the employee, after adding the overtime amount based on the following criteria.
- If hours are more than 40, then 5000 are added to salary as an overtime amount
- If hours are between 30 and 40 (both inclusive), then 3000 are added to salary as an overtime amount
- If hours are less than 30, then the salary remains unchanged The details of the members of both the classes are given below:
Class name | EmpSal |
Data members/instance variables: | |
empnum | to store the name of the employee |
empcode | integer to store the employee code |
salary | to store the salary of the employee in decimal |
Methods/Member functions: | |
EmpSal(...) | parameterised constructor to assign values to data members |
void show() | to display the details of the employee |
Class name | Overtime |
Data members/instance variables: | |
hours | integer to store overtime in hours |
totsal | to store the total salary in decimal |
Methods/Member functions: | |
Overtime(....) | parameterised constructor to assign values to data members of both the classes |
void calSal() | calculates the total salary by adding the overtime amount to salary as per the criteria given above |
void show() | to display the employee details along with the total salary (salary +overtime amount) |
Assume that the super class EmpSal has been defined. Using the concept of inheritance, specify the class Overtime giving the details of the constructer (...), void calSal() and void show().
The super class, main function and algorithm need NOT be written.
Concept: Base and Derived Classes
The keyword used by a class to acquire the properties of an interface is:
Concept: Basic Data Structures (Stack, Queue, Dequeue)
State the principle by which the stack data structure works.
Concept: Basic Data Structures (Stack, Queue, Dequeue)
Convert the following infix notation to postfix notation:
A * (B + C / D ) – E / F
Concept: Conversion of Infix to Prefix and Post Fix Notations
Answer the following question on the diagram of a Binary Tree given below:
State the degree of the nodes C and G. Also, state the level of these nodes when the root is at level 0.
Concept: Recursive Data Structures - Single Linked List (Algorithm and Programming), Binary Trees, Tree Traversals (Conceptual)
Answer the following question on the diagram of a Binary Tree given below:
Write the pre-order and post-order traversal of the above tree structure.
Concept: Recursive Data Structures - Single Linked List (Algorithm and Programming), Binary Trees, Tree Traversals (Conceptual)
A Queue is a linear data structure in which the operations are performed based on FIFO (First In First Out).
Define a class Queue with the following details:
Class name | Queue |
Data member/instance variable: | |
dat[ ] | array to hold the integer elements |
cap | stores the maximum capacity of the queue |
front | to point the index of the front |
rear | to point the index of the rear |
Member functions/methods: | |
Queue(int max) | constructor to initialize the data member cap = max, front = rear = 0 and create the integer array |
void add_dat(int v) | to add integers from the rear index if possible else display the message(“Queue full”) |
int pop_dat( ) | to remove and return elements from front, if any, else returns -999 |
void display() | to display elements of the queue |
Specify the class Queue giving the details of void add_dat(int) and int pop_dat( ). Assume that the other functions have been defined.
The main( ) function and algorithm need NOT be written.
Concept: Basic Data Structures (Stack, Queue, Dequeue)
Convert the following infix notation to postfix form.
(P + Q * R - S)/T * U
Concept: Conversion of Infix to Prefix and Post Fix Notations
CardGame is a game of mental skill, built on the simple premise of adding and removing the cards from the top of the card pile.
The details of the class CardGame are given below.
Class name | CardGame |
Data members/instance variables: | |
cards[] | array to store integers as cards |
cap | to store the maximum capacity of array |
top | to store the index of the topmost element of the array |
Methods/Member functions: | |
CardGame(int cc) | constructor to initialise cap=cc and top= -1 |
void addCard(int v) | to add the card at the top index if possible, otherwise display the message “CARD PILE IS FULL” |
int drawCard( ) | to remove and return the card from the top index of the card pile, if any, else return the value -9999 |
void display( ) | to display all the cards of card pile |
- Specify the class CardGame giving details of the functions void addCard(int) and int drawCard( ). Assume that the other functions have been defined.
The main() function and algorithm need NOT be written. - Name the entity described above and state its principle.
Concept: Implementation Directly Through Classes
Answer the following questions based on the diagram of a Binary Tree given below:
- Name the external nodes of the tree.
- State the degree of node M and node L.
- Write the post-order traversal of the above tree structure.
Concept: Recursive Data Structures - Single Linked List (Algorithm and Programming), Binary Trees, Tree Traversals (Conceptual)
Convert the following infix notation to prefix form.
( A – B ) / C * ( D + E )
Concept: Conversion of Infix to Prefix and Post Fix Notations
Recycle is an entity which can hold at the most 100 integers. The chain enables the user to add and remove integers from both the ends i.e. front and rear.
Define a class ReCycle with the following details:
Class name | ReCycle |
Data members/instance variables: | |
ele[ ] | the array to hold the integer elements |
cap | stores the maximum capacity of the array |
front | to point the index of the front |
rear | to point the index of the rear |
Methods / Member functions: | |
ReCycle (int max) | constructor to initialize the data cap = max, front = rear = 0 and to create the integer array. |
void pushfront(int v) | to add integers from the front index if possible else display the message(“full from front”). |
int popfront( ) | to remove the return elements from front. If array is empty then return-999 |
void pushrear(int v) | to add integers from the front index if possible else display the message(“full from rear”). |
int poprear( ) | to remove and return elements from rear. If the array is empty then return-999. |
- Specify the class ReCycle giving details of the functions void pushfront(int) and int poprear( ). Assume that the other functions have been defined.
The main( ) function and algorithm need NOT be written. - Name the entity described above and state its principle.
Concept: Basic Algorithms and Programs Using the Above Data Structures
A linked list is formed from the objects of the class Node. The class structure of the Node is given below:
class Node
{
int n;
Node link;
}
Write an Algorithm OR a Method to search for a number from an existing linked list. The method declaration is as follows:
void FindNode( Node str, int b)
Concept: Recursive Data Structures - Single Linked List (Algorithm and Programming), Binary Trees, Tree Traversals (Conceptual)
Answer the following questions from the diagram of a Binary Tree given below:
- Name the root of the left sub tree and its siblings.
- State the size and depth of the right sub tree.
- Write the in-order traversal of the above tree structure.
Concept: Recursive Data Structures - Single Linked List (Algorithm and Programming), Binary Trees, Tree Traversals (Conceptual)
With the help of an example, briefly explain the dominant term in complexity.
Concept: Importance of Dominant Term
For Big O notation, state the difference between O(n) and O(n2 ).
Concept: Big O Notation for Computational Complexity