- Class 12 Java Program
- ISC Java Programs - Home
- Year 2025 Theory Programs
- Pernicious Number Program
- Check Matrix Column Sum Program
- Flipgram (Heterogram) Program
- Circular Queue Program
- Flight Passenger Inheritance Program
- Year 2025 Practical Programs
- Goldbach Number Program
- Shift Matrix Rows Up Program
- Pangram String Program
- Later Date Program
- Symmetric Matrix Program
- Cell Phone Keypad Program
- Unique Digit Integer Program
- Max & Min Elements in Matrix Program
- Anagram Strings Program
- Year 2025 Specimen Theory Programs
- Mask String Program Specimen
- Mix Array Program Specimen
- LCM using Recursion Program Specimen
- Recycle Dequeue Program Specimen
- Library Compute Inheritance Program Specimen
- Linked List & Binary Tree Question Specimen
- Year 2024 Programs
- Decimal to Hexadecimal Program
- Insertion Sort Program
- Lowest & Highest ASCII Value Program
- Card Game Stack Program
- Employee Salary Overtime Inheritance Program
- Binary Tree 2024 Questions
- Hamming Number Program
- Doubly Markov Matrix Program
- Snowball String Program
- Future Date Program
- Lucky Number Program
- Bar Graph of Vowels & Consonants Program
- Vampire Number Program
- Rotate Matrix by 270 Degree Anticlockwise Program
- Keyword Cipher Program
- Year 2023 Programs
- Increasing, Decreasing & Bouncy Number Program
- Fill Matrix with Characters Program
- Decode Encoded Text Program
- Project Submission Date Program
- Sort Matrix Boundary Elements Program
- Insert Word in a Sentence Program
- Composite Magic Number Program
- Mirror Image of a Matrix Program
- Common Words in a Paragraph Program
- Dudeney Number Recursive Program
- Matrix Transpose Program
- Sort Words Alphabetically Program
- DeQueue Data Structure Program
- Demand Supply Inheritance Program
- Linked List & Binary Tree Question
- Year 2023 Specimen Theory Programs
- Pronic Number in Java using Recursion
- Year 2022 Programs
- Unique Word Program
- No Repeated Alphabets Program
- Calculate Series Program
- Reverse Number using Recursion Program
- Item Taxable Inheritance Program
- Stack Data Structure Program
- Year 2021 Programs
- Evil Number Program
- Merge Two Arrays Program
- Remove Repeated Alphabets Program
- Rack Stack Data Structure Program
- Stock Sales Inheritance Program
- Year 2020 Theory Programs
- Date and Month Program
- Binary Search using Recursion Program
- Mix Two Words Program
- Circular Queue Program
- Data Interface Program
- Year 2020 Practical Programs
- Prime Adam Number Program
- Octal to Decimal Conversion Program
- Arrange Words Length-wise Program
- Year 2019 Theory Programs
- Armstrong Number Program
- Reverse Matrix Elements Program
- Rearrange Vowels & Consonants Program
- Record & Highest Inheritance Program
- Diary Class Queue Program
- Linked List and Binary Tree Program
- Year 2019 Practical Programs
- Generate Date Program
- Array Format Program
- Generate Palindrome Words
- Year 2018 Theory Programs
- Perfect Number Program on Recursion
- Checking for Equal Matrices
- Words Beginning with Capital Letter
- Number Series Inheritance Program
- Register Stack Program
- Year 2018 Practical Programs
- Goldbach Number Program
- Sorting Two-Dimensional Matrix Program
- Vertical Banner Program
- Year 2017 Theory Programs
- Palindrome using Recursion Program
- Adder Program
- Swap Sort Program
- Product Sales Inheritance Program
- Queue Program on Array
- Year 2017 Practical Programs
- Cartons Program
- Quiz Program
- Caesar Cipher Program
- Year 2016 Theory Programs
- Disarium Number Recursive Program
- Shift Matrix Shuffle Program
- ConsChange Program
- Bank Account Inheritance Program
- Bookshelf Stack Program
- Year 2016 Practical Programs
- Circular Prime Program
- Sort Non-boundary Matrix Elements Program
- Words Beginning and Ending with Vowels Program
- Year 2015 Theory Programs
- Admission Recursive Binary Search Program
- Merger Class Concatenation Program
- String Frequency Program
- WordPile Stack Program
- Plane Circle Inheritance Program
- Year 2015 Practical Programs
- Smallest Integer Program
- Rotate Matrix 90 Degrees Program
- Vowels and Consonants Per Word Program
- Year 2014 Theory Programs
- Merging Sorted Arrays Program
- Series Sum Program
- Fibonacci Strings Program
- Stock Purchase Inheritance Program
- Array to Stack Program
- Year 2014 Practical Programs
- Composite Magic Program
- Symmetric Matrix Program
- Deleting Word from String Program
- Year 2013 Theory Programs
- Emirp Number Program
- Exchange Alphabets Program
- Matrix Difference Program
- Perimeter Area Inheritance Program
- Dequeue Queue Program
- Year 2013 Practical Programs
- ISBN Code Program
- Mirror Image Matrix Program
- Palindrome Words Program
- Year 2012 Theory Programs
- Combine Array Program
- Vowel Word Program
- Happy Number Program
- Link Queue Program
- Detail Bill Inheritance Program
- Year 2012 Practical Programs
- Prime Palindrome Program
- Arrange Words Alphabetically Program
- Sort Matrix Elements Program
- Year 2011 Theory Programs
- Frequency of “And” and “An” Program
- Decimal to Octal Conversion Program
- Pseudo Arithmetic Sequence Program
- Record Rank Inheritance Program
- Stack Program Storing Names
- Year 2011 Practical Programs
- Number to Words Conversion Program
- Year 2009 Theory Programs
- Magic Number Program
- Year 2008 Theory Programs
- Special Number Program
- Year 2007 Theory Programs
- Triangular Number Program
Java Programs - Solved 2023 Theory Paper ISC Computer Science
![]() Share with a Friend |
Solved 2023 Thory Paper ISC Computer Science
Class 12 - ISC Computer Science Solved Theory Papers
DeQueue Data Structure Program - ISC 2023 Theory
A double-ended queue is a linear data structure which enables the user to add and remove integers from either ends i.e. from front or rear.
The details of the class DeQueue are given below:
Class name: DeQueue
Data members/instance variables:
qrr[]: array to hold integer elements
lim: maximum capacity of the dequeue
front: to point the index of the front end
rear: to point the index of the rear end
Methods/Member functions:
DeQueue(int l): constructor to initialize lim = l, front = 0 and rear = 0
void addFront(int v): to add integers in the dequeue at the front end if possible, otherwise display the message “OVERFLOW FROM FRONT”
void addRear(int v): to add integers in the dequeue at the rear end if possible, otherwise display the message “OVERFLOW FROM REAR”
int popFront(): removes and returns the integers from the front end of the dequeue if any, else returns -999
int popRear(): removes and returns the integers from the rear end of the dequeue if any, else returns -999
void show(): displays the elements of the dequeue
(i) Specify the class DeQueue giving details of the functions void addFront(int) and int popFront(). Assume that the other functions have been defined.
(ii) Differentiate between a stack and a queue.
import java.util.Scanner; class DeQueue{ int qrr[]; int lim; int front; int rear; public DeQueue(int l){ lim = l; qrr = new int[lim]; front = 0; rear = 0; } public void addFront(int v){ if(front == 0) System.out.println("OVERFLOW FROM FRONT"); else qrr[--front] = v; } public void addRear(int v){ if(rear == lim) System.out.println("OVERFLOW FROM REAR"); else qrr[rear++] = v; } public int popFront(){ if(front < rear){ int d = qrr[front++]; if(front == rear){ front = 0; rear = 0; } return d; } return -999; } public int popRear(){ if(front < rear){ int d = qrr[--rear]; if(front == rear){ front = 0; rear = 0; } return d; } return -999; } public void show(){ if(front > rear) System.out.println("DE-QUEUE EMPTY"); else{ for(int i = front; i < rear; i++) System.out.print(qrr[i] + " "); System.out.println(); } } public static void main(String[] args){ Scanner in = new Scanner(System.in); System.out.print("Dequeue limit: "); int size = Integer.parseInt(in.nextLine()); DeQueue dq = new DeQueue(size); while(true){ System.out.println("1. Add from front"); System.out.println("2. Add from rear"); System.out.println("3. Pop from front"); System.out.println("4. Pop from rear"); System.out.println("5. Display elements"); System.out.print("Enter your choice: "); int choice = Integer.parseInt(in.nextLine()); switch(choice){ case 1: System.out.print("Element to be added: "); int v = Integer.parseInt(in.nextLine()); dq.addFront(v); break; case 2: System.out.print("Element to be added: "); v = Integer.parseInt(in.nextLine()); dq.addRear(v); break; case 3: v = dq.popFront(); if(v == -999) System.out.println("Underflow from front"); else System.out.println(v + " popped"); break; case 4: v = dq.popRear(); if(v == -999) System.out.println("Underflow from rear"); else System.out.println(v + " popped"); break; case 5: dq.show(); break; default: System.out.println("Bye!"); return; } } } }
Output
OUTPUT : Dequeue limit: 5 1. Add from front 2. Add from rear 3. Pop from front 4. Pop from rear 5. Display elements Enter your choice: 1 Element to be added: 10 OVERFLOW FROM FRONT 1. Add from front 2. Add from rear 3. Pop from front 4. Pop from rear 5. Display elements Enter your choice: 2 Element to be added: 20 1. Add from front 2. Add from rear 3. Pop from front 4. Pop from rear 5. Display elements Enter your choice: 1 Element to be added: 30 OVERFLOW FROM FRONT 1. Add from front 2. Add from rear 3. Pop from front 4. Pop from rear 5. Display elements Enter your choice: 2 Element to be added: 40 1. Add from front 2. Add from rear 3. Pop from front 4. Pop from rear 5. Display elements Enter your choice: 5 20 40 1. Add from front 2. Add from rear 3. Pop from front 4. Pop from rear 5. Display elements Enter your choice: (ii). A stack is a linear data structure that follows LIFO (Last In First Out) principle. A queue is a linear data structure that follows FIFO (First In First Out) principle.
