KEMBAR78
DS Lab | PDF | Queue (Abstract Data Type) | Computer Programming
0% found this document useful (0 votes)
24 views46 pages

DS Lab

Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
24 views46 pages

DS Lab

Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 46

A D PATEL INSTITUTE OF TECHNOLOGY

DEPARTMENT OF INFORMATION TEECHNOLODGY


DATA STRUCTURES (202040301)

PRACTICAL-1
1. Write a program to insert/delete in linear array at specific
position.

#include <stdio.h>

void main(){

int a[100], n, i, pos, data, c;

printf("Enter The length of Array: ");


scanf("%d", &n);
printf("Enter The Values:\n");

for (i = 0; i < n; i++){


scanf("%d", &a[i]);
}
printf("The Array is:");

for (i = 0; i < n; i++){


printf("%d ", a[i]);
}

printf("\nEnter\n 1 for insert\n2 for delete:");


scanf("%d", &c);

if (c == 1){
printf("\nEnter The Position for insert: ");
scanf("%d", &pos);
printf("Enter The New Value: ");
scanf("%d", &data);

for (i = n - 1; i >= pos; i--){

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 1
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF INFORMATION TEECHNOLODGY
DATA STRUCTURES (202040301)

a[i + 1] = a[i];
}
a[pos] = data;
}

else if (c == 2){
printf("Enter The Position for Delete : ");
scanf("%d", &pos);
for (i = pos; i <= n; i++){
a[i] = a[i + 1];
n--;
}
}
else{
printf("Wrong Input.\n"); }
for (i = 0; i <= n; i++){
printf("%d ", a[i]);
}
}
OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 2
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF INFORMATION TEECHNOLODGY
DATA STRUCTURES (202040301)

2. Write a program to remove duplicate elements from liner array.

#include <stdio.h> int


main(){
int arr[20], i, j, k, n;
printf("Enter The Length: ");
scanf("%d", &n);
printf("Enter The Values:\n");
for (i = 0; i < n; i++){
scanf("%d", &arr[i]);
}

for (i = 0; i < n; i++){


for (j = i + 1; j < n; j++){
if (arr[i] == arr[j]){
for (k = j; k < n - 1; k++){
arr[k] = arr[k + 1];
}
n--;
j--; } }
}
printf(" \n Array Elements after deletion of the Duplicate Elements: ");
for (i = 0; i < n; i++){
printf(" %d \t", arr[i]);
}
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 3
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF INFORMATION TEECHNOLODGY
DATA STRUCTURES (202040301)

OUTPUT

3. Write a program to read 10 integers in an array. Sort them out on


the basis of number of digits in each element.

#include <stdio.h> void


printArray(int *A, int n){
for (int i = 0; i < n; i++){
printf("%d ", A[i]);
}
printf("\n");
}
void bubbleSort(int *A, int n){
int temp;
for (int i = 0; i < n - 1; i++)
{
for (int j = 0; j < n - 1 - i; j++){
if (A[j] > A[j + 1
temp = A[j];
A[j] = A[j + 1];
A[j + 1] = temp;
}
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 4
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF INFORMATION TEECHNOLODGY
DATA STRUCTURES (202040301)

}
}
int main(){
int A[] = {1, 2, 5, 6, 12, 54, 625, 7, 23, 9, 987};
int n = 11; printArray(A, n); bubbleSort(A,
n); printArray(A, n);
}

OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 5
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

PRACTICAL-2
1. Demonstrate the concept of Call by value and Call by Reference.

#include <stdio.h>

void swap1(int a, int b){


int temp = a; a = b;
b = temp;
printf(" inside function a is : %d & b is : %d \n", a, b);
}

void swap2(int *a, int *b){


int temp = *a;
*a = *b; *b =
temp;
printf("inside function a is :%d & b is :%d \n", *a, *b);
}

void main(){
int x = 3, y = 5;

printf(" x is :%d & y is :%d \n", x, y);

swap1(x, y);
printf("after using Call by Value: \n x is :%d & y is :%d \n", x, y);

swap2(&x, &y);
printf("after using Call by Reference: \nx is :%d & y is :%d \n", x, y);
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 6
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

OUTPUT

2. Write a program to prints array elements in reverse orders applying


pointers.

#include <stdio.h>

void reverse(int *arr, int size){


int *ptr = arr + size - 1;
printf("\nArray in Reverse:");
while (ptr >= arr){
printf("%d ", *ptr);
ptr--;
}
}
void main(){
int arr[10], size;

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 7
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

printf("Enter the Size of the Array (Max 10): ");


scanf("%d", &size);

printf("Enter %d Elements: \n", size);


for (int i = 0; i < size; i++){
scanf("%d", &arr[i]);
}
printf("Your Elements: \n");
for (int i = 0; i < size; i++){
printf("%d ", arr[i]);
}
reverse(arr, size);
}

OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 8
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

3. Write program to implement stack and simple queue using array.

#include <stdio.h>
#define MAX_SIZE 10

int stack[MAX_SIZE];
int top = -1;
void push(int data){
if (top >= MAX_SIZE - 1){
printf("Stack Overflow\n");
return;
}
else{
top++;
stack[top] = data;
}
}
int pop(){
if (top < 0){
printf("Stack Underflow\n");
return -1;
}
else{
printf("poped element is : %d\n", stack[top]);
top--;
}
}
void display(){
if (top < 0){
printf("Stack is empty\n");
return;
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 9
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

else{
printf("Elements in the stack are:\n");
for (int i = top; i >= 0; i--){
printf("%d\n", stack[i]);
}
}
}

int queue[MAX_SIZE];
int front = -1, rear = -1;
void enqueue(int x){ if
(rear == MAX_SIZE - 1){
printf("your queue is full.");
}
else{ if
(front == -1){
front++;
}
printf("enque element is : %d \n", x);
rear++;
queue[rear] = x;
}
}

void dequeue(){
if (rear == -1){
printf("queue is empty.");
}
else{
printf("dequeue element is : %d\n", queue[front]);
front++;

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 10
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

if (front > rear){


front = rear = -1;
}
}
}
void display_queue(){
if (front == -1 || front > rear){
printf("Queue is empty\n");
return;
}
printf("Elements in the queue are:\n");
for (int i = front; i <= rear; i++){
printf("%d\n", queue[i]);
}
}
void main(){
push(20);
push(30);
display(); pop();
display();

enqueue(10);

enqueue(20);
enqueue(30);
display_queue();
dequeue();
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 11
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 12
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

PRACTICAL-3
1. Write a program for stack using array for the following
operations: Push, Pop, Peek and IsEmpty.

#include <stdio.h>
#define MAX_SIZE 10
int stack[MAX_SIZE];
int top = -1;
void push(int data){
if (top >= MAX_SIZE - 1){
printf("Stack Overflow\n");
return;
}
else{
top++;
stack[top] = data;
}
}
int pop(){
if (top < 0){
printf("Stack Underflow\n");
return -1;
}
else{
printf("Poped Element is : %d\n", stack[top]);
top--;
}
}
void display(){
if (top < 0){
printf("Stack is empty\n");
return;

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 13
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

}
else{
printf("Elements in the Stack is:\n");
for (int i = top; i >= 0; i--)
printf("%d\n", stack[i]);
}
}
void main(){
push(20);
push(30);
display(); pop();
display();
}

OUTPUT

2. Write a program for queue using array for the following


operations: Enqueue, Dequeue, IsEmpty, IsFull.

#include <stdio.h>
#define size 5

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 14
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

int a[size];
int front = -1, rear = -1;

void enqueue(int x){


if (rear == size - 1){
printf("Your Queue is Full.");
}
else{ if
(front == -1){
front++;
}
printf("Enque Element is: %d \n", x);
rear++;
a[rear] = x;
}
}

void dequeue(){
if (rear == -1){
printf("Queue is Empty.");
}
else{
printf("Dequeue Element is: %d\n", a[front]);
front++;

if (front > rear){


front = rear = -1;
}
}
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 15
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

void print(){ if (rear == -1){


printf("\nQueue is Empty");
}
else{
printf("\nYour Queue Element is : ");
for (int i = front; i <= rear; i++){
printf(" %d ", a[i]);
}
}
}

void main(){
enqueue(1);
enqueue(2);
enqueue(3);
enqueue(4);
dequeue();
enqueue(1);
dequeue();
dequeue();
dequeue();
dequeue();
enqueue(1);
enqueue(1);
enqueue(2);
enqueue(3);
enqueue(4);
enqueue(4);

print();
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 16
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 17
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

3. Write a program for circular queue using array for the


following operations: Enqueue, Dequeue, IsEmpty, IsFull.

#include <stdio.h>
#define size 5

int a[size];
int front = -1, rear = -1;

void enqueue(int x){


if (front == rear + 1 || front == 0 && rear == size - 1){
printf("\nThe Queue is Full.\n");
}
else{ if
(front == -1){
front++;
}
printf("\nEnque Element is: %d \n", x);
rear = ++rear % size;
a[rear] = x;
}
printf("front = %d rear = %d\n", front, rear);
}

void dequeue(){
if (front == -1){
printf("\nQueue is Empty.\n");
}
else{

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 18
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

printf("\nDequeue Element is : %d\n", a[front]);


front++;
}
if (front == rear + 1){
front = rear = -1;
}

printf("front = %d rear = %d\n", front, rear);


}

void print(){ if
(rear == -1){
printf("\nQueue is Empty\n");
}
else{
printf("\nThe Queue Element is : ");
for (int i = 0; i <= 4; i++){ printf("
%d ", a[i]);
}
printf("\nfront = %d rear = %d\n", front, rear);
}
}

void main(){
dequeue();

enqueue(1);
enqueue(2);
enqueue(3);
enqueue(4);
enqueue(5);
enqueue(6);

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 19
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

dequeue();
enqueue(7);
enqueue(8); print();
}
OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 20
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

PRACTICAL-4
1. Write a program for single linked list for the following operations:
i. Count the number of nodes in a given linked list
ii. Delete the desired node from linked list
iii. Insert the new node after the desired node into the linked list
iv. Create a new list by reversing the list
v. Concatenates two linked list

#include <stdio.h>
#include <stdlib.h>

struct Node {
int data;
struct Node* next;
};

struct Node* createNode(int data) {


struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data; newNode->next = NULL;
return newNode;
}

int countNodes(struct Node* head) {


int count = 0; struct Node* temp =
head; while (temp != NULL) {
count++;
temp = temp->next;
}
return count;
}
void deleteNode(struct Node** head, int key) {
struct Node* temp = *head, *prev = NULL;

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 21
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

if (temp != NULL && temp->data == key) {


*head = temp->next;
free(temp);
return;
}

while (temp != NULL && temp->data != key) {


prev = temp;
temp = temp->next;
}

if (temp == NULL) return;

prev->next = temp->next;
free(temp);
}

void insertAfter(struct Node* head, int key, int data) {


struct Node* temp = head;

while (temp != NULL && temp->data != key) {


temp = temp->next;
}

if (temp == NULL) {
printf("Node with value %d not found.\n", key);
return;
}

struct Node* newNode = createNode(data


newNode->next = temp->next;

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 22
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

temp->next = newNode;
}

struct Node* reverseList(struct Node* head) {


struct Node *prev = NULL, *current = head, *next = NULL;

while (current != NULL) {


next = current->next;
current->next = prev;
prev = current;
current = next;
}
return prev;
}

struct Node* concatenateLists(struct Node* head1, struct Node* head2) {


if (head1 == NULL) return head2;
if (head2 == NULL) return head1;

struct Node* temp = head1;


while (temp->next != NULL) {
temp = temp->next;
}
temp->next = head2;

return head1;
}

void displayList(struct Node* head) {


struct Node* temp = head; while
(temp != NULL) { printf("%d -> ",

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 23
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

temp->data); temp = temp-


>next;
}
printf("NULL\n");
}
void main() {
struct Node* head1 = NULL;
struct Node* head2 = NULL;

head1 = createNode(10); head1-


>next = createNode(20); head1->next-
>next = createNode(30);

head2 = createNode(40); head2-


>next = createNode(50);
head2->next->next = createNode(60);

printf("First Linked List: ");


displayList(head1);

printf("Second Linked List: ");


displayList(head2);

printf("Number of nodes in first list: %d\n", countNodes(head1));

deleteNode(&head1, 20);
printf("List after deleting node with value 20: ");
displayList(head1);

insertAfter(head1, 10, 25);


printf("List after inserting node with value 25 after node with value 10: ");
displayList(head1);

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 24
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

head1 = reverseList(head1);
printf("First list after reversal: ");
displayList(head1);

head1 = concatenateLists(head1, head2);


printf("Concatenated list: ");
displayList(head1);
}

OUTPUT

2. Write a program for stack using linked list for the following operations:
Push, Pop, Peek and IsEmpty.

#include <stdio.h>
#include <stdlib.h>

struct Node {
int data;
struct Node* next;
};

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 25
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

struct Node* createNode(int data) {


struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data;
newNode->next = NULL;
return newNode;
}

int isEmpty(struct Node* top) {


return top == NULL;
}

void push(struct Node** top, int data) {


struct Node* newNode = createNode(data);
newNode->next = *top; *top = newNode;
printf("Pushed %d onto the stack.\n", data);
}

int pop(struct Node** top) {


if (isEmpty(*top)) {
printf("Stack Underflow! Cannot pop element.\n");
return -1;
}
struct Node* temp = *top;
int poppedData = temp->data;
*top = (*top)->next;
free(temp); return
poppedData;
}

int peek(struct Node* top) {


if (isEmpty(top)) {

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 26
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

printf("Stack is empty! Cannot peek element.\n");


return -1;
}
return top->data;
}

void displayStack(struct Node* top) {


if (isEmpty(top)) {
printf("Stack is empty.\n");
return;
}
struct Node* temp = top;
printf("Stack elements: ");
while (temp != NULL) {
printf("%d -> ", temp->data);
temp = temp->next;
}
printf("NULL\n");
}

void main() {
struct Node* stack = NULL;

push(&stack, 10);
push(&stack, 20);
push(&stack, 30);

displayStack(stack);

printf("Top element (peek): %d\n", peek(stack));

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 27
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

printf("Popped element: %d\n", pop(&stack));


printf("Popped element: %d\n", pop(&stack));

displayStack(stack);

if (isEmpty(stack)) {
printf("Stack is empty.\n");
} else {
printf("Stack is not empty.\n");
}

OUTPUT

3. Write a program for queue using linked list for the following
operations: Enqueue, Dequeue, IsEmpty

#include <stdio.h>
#include <stdlib.h>

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 28
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

struct Node {
int data;
struct Node* next;
};

struct Queue {
struct Node *front, *rear;
};

struct Node* createNode(int data) {


struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data;
newNode->next = NULL;
return newNode;
}

void initQueue(struct Queue* q) {


q->front = q->rear = NULL;
}

int isEmpty(struct Queue* q) {


return q->front == NULL;
}

void enqueue(struct Queue* q, int data) {


struct Node* newNode = createNode(data);
if (q->rear == NULL) { q-
>front = q->rear = newNode;
printf("Enqueued %d into the queue.\n", data);
return;
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 29
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

q->rear->next = newNode;
q->rear = newNode;
printf("Enqueued %d into the queue.\n", data);
}

int dequeue(struct Queue* q) {


if (isEmpty(q)) {
printf("Queue Underflow! Cannot dequeue element.\n");
return -1;
}
struct Node* temp = q->front;
int dequeuedData = temp->data;
q->front = q->front->next;

if (q->front == NULL)
q->rear = NULL;

free(temp);
return dequeuedData;
}

void displayQueue(struct Queue* q) {


if (isEmpty(q)) {
printf("Queue is empty.\n");
return;
}
struct Node* temp = q->front;
printf("Queue elements: ");
while (temp != NULL) {
printf("%d -> ", temp->data);
temp = temp->next;
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 30
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

printf("NULL\n");
}
void main() {
struct Queue queue;
initQueue(&queue);

enqueue(&queue, 10);
enqueue(&queue, 20);
enqueue(&queue, 30);

displayQueue(&queue);

printf("Dequeued element: %d\n", dequeue(&queue));


printf("Dequeued element: %d\n", dequeue(&queue));
displayQueue(&queue);
if (isEmpty(&queue)) {
printf("Queue is empty.\n");
} else {
printf("Queue is not empty.\n");
}
}
OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 31
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

PRACTICAL-5

1. Write a program of conversion of an expression from infix to


Postfix, Prefix

#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>

#define MAX 100

struct Stack {
int top;
char arr[MAX];
};

void initStack(struct Stack *s) {


s->top = -1;
}

int isEmpty(struct Stack *s) {


return s->top == -1;
}

void push(struct Stack *s, char ch) {


if (s->top < MAX - 1) {
s->arr[++(s->top)] = ch;
}
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 32
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

char pop(struct Stack *s) {


if (!isEmpty(s)) {
return s->arr[(s->top)--];
}
return '\0';
}

char peek(struct Stack *s) {


if (!isEmpty(s)) {
return s->arr[s->top];
}
return '\0';
}

int isOperator(char ch) {


return ch == '+' || ch == '-' || ch == '*' || ch == '/' || ch == '^';
}

int precedence(char ch) { if (ch


== '^') return 3; if (ch == '*' ||
ch == '/') return 2; if (ch == '+' ||
ch == '-') return 1; return 0;
}

void reverseString(char *str) {


int len = strlen(str);
for (int i = 0; i < len / 2; i++) {
char temp = str[i];
str[i] = str[len - i - 1];
str[len - i - 1] = temp;
}
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 33
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

void infixToPostfix(char* infix, char* postfix) {


struct Stack s;
initStack(&s); int
k = 0;

for (int i = 0; infix[i] != '\0'; i++) {


char ch = infix[i];

if (isalnum(ch)) {
postfix[k++] = ch; // If character is operand, add it to result
}
else if (ch == '(') {
push(&s, ch); // Push '(' to stack
}
else if (ch == ')') {
while (!isEmpty(&s) && peek(&s) != '(') {
postfix[k++] = pop(&s); // Pop until '(' is found
}
pop(&s); // Discard the '('
}
else if (isOperator(ch)) {
while (!isEmpty(&s) && precedence(peek(&s)) >= precedence(ch)) {
postfix[k++] = pop(&s); // Pop higher or equal precedence operators
}
push(&s, ch);
}
}

while (!isEmpty(&s)) {
postfix[k++] = pop(&s); // Pop remaining operators
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 34
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

postfix[k] = '\0'; // Null terminate the postfix expression


}

void infixToPrefix(char* infix, char* prefix) {


struct Stack s; initStack(&s);
reverseString(infix);

// Swap '(' and ')'


for (int i = 0; infix[i] != '\0'; i++) {
if (infix[i] == '(') infix[i] = ')';
else if (infix[i] == ')') infix[i] = '('; }

char postfix[MAX];
infixToPostfix(infix, postfix);
reverseString(postfix);
strcpy(prefix, postfix);
}

void main() {
char infix[MAX], postfix[MAX], prefix[MAX];

printf("Enter an infix expression: ");


scanf("%s", infix);

infixToPostfix(infix, postfix);
printf("Postfix Expression: %s\n", postfix);

infixToPrefix(infix, prefix);
printf("Prefix Expression: %s\n", prefix);

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 35
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

OUTPUT

2. Write a program to evaluate postfix expression.

#include <stdio.h>
#include <ctype.h>
#include <stdlib.h>

struct Stack {
int top; int
arr[100];
};

void initStack(struct Stack *s) {


s->top = -1;
}

int isEmpty(struct Stack *s) {


return s->top == -1;
}

void push(struct Stack *s, int value) {

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 36
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

s->arr[++(s->top)] = value;
}

int pop(struct Stack *s) {


if (!isEmpty(s)) {
return s->arr[(s->top)--];
}
return -1; // Stack underflow condition (shouldn't happen in a valid postfix)
}

int evaluatePostfix(char* exp) {


struct Stack s;
initStack(&s);
for (int i = 0; exp[i] != '\0'; i++)
{ char ch = exp[i];

// If the character is an operand (digit), push it to stack


if (isdigit(ch)) {
push(&s, ch - '0'); // Convert char digit to int
}
// If the character is an operator
else {
int operand2 = pop(&s);
int operand1 = pop(&s);

switch (ch) {
case '+':
push(&s, operand1 + operand2);
break;
case '-':
push(&s, operand1 - operand2);

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 37
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

break;
case '*':
push(&s, operand1 * operand2);
break;
case '/':
push(&s, operand1 / operand2);
break;
}
}
}

return pop(&s);
}

void main() {
char exp[100];

printf("Enter a postfix expression: ");


scanf("%s", exp);

int result = evaluatePostfix(exp);


printf("Result of postfix expression: %d\n", result);

OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 38
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 39
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 40
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

PRACTICAL-6
1. Write a program to implement doubly linked list for the following
operations:
i. Insert a new node after the desired node
ii. Delete the desired note
iii. Display the nodes of doubly linked list

#include <stdio.h>
#include <stdlib.h>

struct Node {
int data;
struct Node* prev;
struct Node* next;
};

struct Node* createNode(int data) {


struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data;
newNode->prev = NULL;
newNode->next = NULL;
return newNode;
}

void insertAfter(struct Node* prevNode, int data) {


if (prevNode == NULL) {
printf("Previous node cannot be NULL\n");
return;
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 41
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

struct Node* newNode = createNode(data);


newNode->next = prevNode->next;
prevNode->next = newNode;
newNode->prev = prevNode;

if (newNode->next != NULL) {
newNode->next->prev = newNode;
}
printf("Inserted node %d after node %d\n", data, prevNode->data);
}

void deleteNode(struct Node** headRef, struct Node* delNode) {


if (*headRef == NULL || delNode == NULL) {
printf("Node to be deleted is NULL or list is empty\n");
return;
}

if (*headRef == delNode) {
*headRef = delNode->next;
}

if (delNode->next != NULL) {
delNode->next->prev = delNode->prev;
}

if (delNode->prev != NULL) {
delNode->prev->next = delNode->next;
}

printf("Deleted node %d\n", delNode->data);


free(delNode);
}

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 42
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

void displayList(struct Node* node) {


struct Node* last;
printf("Doubly linked list in forward order: ");
while (node != NULL) {
printf("%d ", node->data);
last = node;
node = node->next; }
printf("\n"); }

void main() {
struct Node* head = createNode(10);
struct Node* second = createNode(20);
struct Node* third = createNode(30);
head->next = second;
second->prev = head;
second->next = third;
third->prev = second;
displayList(head);
insertAfter(second, 25);
displayList(head);
deleteNode(&head, second);
displayList(head);
}
OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 43
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

2. Write a program to implement circular doubly linked list for the


following operations:
i. Insert a new node after the desired node
ii. Delete the desired note
iii. Display the nodes of doubly linked list

#include <stdio.h>
#include <stdlib.h>

struct Node {
int data;
struct Node* prev;
struct Node* next;
};

struct Node* createNode(int data) {


struct Node* newNode = (struct Node*)malloc(sizeof(struct Node));
newNode->data = data; newNode->prev = newNode; newNode-
>next = newNode;
return newNode;
}

void insertAfter(struct Node* prevNode, int data) {


if (prevNode == NULL) {
printf("Previous node cannot be NULL\n");
return;
}

struct Node* newNode = createNode(data);


newNode->next = prevNode->next;
prevNode->next = newNode;
newNode->prev = prevNode;

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 44
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

newNode->next->prev = newNode;
}

void deleteNode(struct Node** headRef, struct Node* delNode) {


if (*headRef == NULL || delNode == NULL) {
printf("Node to be deleted is NULL or list is empty\n");
return;
}

if (*headRef == delNode) { if
(delNode->next == delNode) {
*headRef = NULL;
} else {
*headRef = delNode->next;
}
}

delNode->prev->next = delNode->next;
delNode->next->prev = delNode->prev;

printf("Deleted node %d\n", delNode->data);


free(delNode);
}

void displayList(struct Node* head) {


if (head == NULL) {
printf("List is empty.\n");
return;
}

struct Node* temp = head;


printf("Circular Doubly Linked List: ");

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 45
A D PATEL INSTITUTE OF TECHNOLOGY
DEPARTMENT OF COMPUTER SCIENCE AND DESIGN DATA
STRUCTURES (202040301)

do {
printf("%d ", temp->data);
temp = temp->next; } while
(temp != head); printf("\n");
}

void main() {
struct Node* head = createNode(10);
struct Node* second = createNode(20);
struct Node* third = createNode(30);

head->next = second;
second->prev = head;
second->next = third;
third->prev = second;
third->next = head;
head->prev = third;

displayList(head);

insertAfter(second, 25);
displayList(head);
deleteNode(&head, second); displayList(head);
}
OUTPUT

NAME : Solanki Mahek D.


ENROLLMENT NO. : 12302080601151 46

You might also like