Answer
Answer
#include <iostream>
struct Item
int itemNo;
float price;
};
int main()
Item *itemPtrs[15];
//Insert
itemPtrs[index]->itemNo = index+1;
if(index == 0)
itemPtrs[index]->price = 1.89;
else if(index == 4)
itemPtrs[index]->price = 2.0;
}
else
float itemPrice;
cin>>itemPrice;
itemPtrs[index]->price = itemPrice;
//Traverse
//Delete
int position;
cin>>position;
itemPtrs[index]->itemNo = itemPtrs[index+1]->itemNo;
itemPtrs[index]->price = itemPtrs[index+1]->price;
}
//Traverse
return 0;
Output:
Qno2:
Answer:
(a)
If{
C1
C2
C3
Fifth loop
C4
(N1+c1.n2) * n3 * n4 * n5
O(1) best
(b)
Constant c 1;
Constant c 2;
C1 * n ;
C2
N + (c1*n)+c2+n
C2 +c1.n+2n
(c )
Sum ++; // c 1
Sum ++; // c 2
(d)
If{
Constant time
Else{
Constant times
}
O(1)+O(n)
Qno3:
Answer:
#include <iostream>
class node
public:
int data;
node *p;
};
void add_node()
cin>>temp->data;
temp->p=NULL;
if(head==NULL)
head=t=temp;
else
t->p=temp;
t=t->p;
}
}
void showNode ()
cout<<t->data<<" ";
int count=0;
for(t=head;t!=NULL;t=t->p)
if(t->data==-1)
count++;
int main()
{
add_node();
showNode();
cout<<endl;
countNode(head);
Output:
Qno4:
Answer:
Bubble Sort:
#include <iostream>
class node
public:
int data;
node *p;
};
void add_node()
cin>>temp->data;
temp->p=NULL;
if(head==NULL)
head=t=temp;
else
t->p=temp;
t=t->p;
void showNode ()
{
for(t=head;t!=NULL;t=t->p)
cout<<t->data<<" ";
int count=0;
for(t=head;t!=NULL;t=t->p)
if(t->data==5)
count++;
void sort()
for (nodeCtr=13;nodeCtr>=0;nodeCtr--)
temp=head;
t=temp->p;
for(ctr=0;ctr<=nodeCtr;ctr++)
nodeDataCopy= temp->data;
temp->data= t->data;
t->data=nodeDataCopy;
temp=t;
t=t->p;
int main()
add_node();
showNode();
cout<<endl;
countNode(head);
sort();
showNode();
Binary Search :
#include <iostream>
class node
public:
int data;
node *p;
};
void add_node()
cin>>temp->data;
temp->p=NULL;
if(head==NULL)
head=t=temp;
else
t->p=temp;
t=t->p;
void showNode ()
{
for(t=head;t!=NULL;t=t->p)
cout<<t->data<<" ";
int count=0;
for(t=head;t!=NULL;t=t->p)
if(t->data==-1)
count++;
void sort()
for (nodeCtr=13;nodeCtr>=0;nodeCtr--)
temp=head;
t=temp->p;
for(ctr=0;ctr<=nodeCtr;ctr++)
nodeDataCopy= temp->data;
temp->data= t->data;
t->data=nodeDataCopy;
temp=t;
t=t->p;
node* middle ()
if (head == NULL)
return NULL;
if (fast != NULL)
}
return slow;
void binarySearch()
cout<<mid->data;
int main()
add_node();
showNode();
cout<<endl;
countNode(head);
sort();
showNode();
cout<<endl;
binarySearch();
Append:
#include <iostream>
class node
public:
int data;
node *p;
};
void add_node()
cin>>temp->data;
temp->p=NULL;
if(head==NULL)
head=t=temp;
}
else
t->p=temp;
t=t->p;
void showNode ()
for(t=head;t!=NULL;t=t->p)
cout<<t->data<<" ";
int count=0;
for(t=head;t!=NULL;t=t->p)
if(t->data==-1)
count++;
void sort()
{
for (nodeCtr=13;nodeCtr>=0;nodeCtr--)
temp=head;
t=temp->p;
for(ctr=0;ctr<=nodeCtr;ctr++)
nodeDataCopy= temp->data;
temp->data= t->data;
t->data=nodeDataCopy;
temp=t;
t=t->p;
node* middle ()
if (head == NULL)
return NULL;
if (fast != NULL)
return slow;
void binarySearch()
cout<<mid->data;
}
void append(node** head_ref)
cin>>temp->data;
temp->p=NULL;
last = last->p;
last->p = temp;
return;
int main()
add_node();
showNode();
cout<<endl;
countNode(head);
sort();
showNode();
cout<<endl;
binarySearch();
cout<<endl;
append(&head);
showNode();
Answer:
#include <iostream>
class node
public:
int data;
node *p;
};
void add_node()
cin>>temp->data;
temp->p=NULL;
if(head==NULL)
{
head=t=temp;
else
t->p=temp;
t=t->p;
void showNode ()
for(t=head;t!=NULL;t=t->p)
cout<<t->data<<" ";
int count=0;
for(t=head;t!=NULL;t=t->p)
if(t->data==-1)
count++;
}
void sort()
for (nodeCtr=13;nodeCtr>=0;nodeCtr--)
temp=head;
t=temp->p;
for(ctr=0;ctr<=nodeCtr;ctr++)
nodeDataCopy= temp->data;
temp->data= t->data;
t->data=nodeDataCopy;
temp=t;
t=t->p;
node* middle ()
if (head == NULL)
return NULL;
if (fast != NULL)
return slow;
void binarySearch()
cout<<mid->data;
}
void append(node** head_ref)
cin>>temp->data;
temp->p=NULL;
last = last->p;
last->p = temp;
return;
else {
while (pos--) {
if (pos == 0) {
temp->p=NULL;
temp->p = *current;
*current = temp;
else
current = &(*current)->p;
int main()
add_node();
}
cout<<"The list of data entered is here: "<<endl;
showNode();
cout<<endl;
countNode(head);
sort();
showNode();
cout<<endl;
binarySearch();
cout<<endl;
append(&head);
showNode();
cout<<endl;
int pos=11;
insertPos(&head, pos);
showNode();
Answer:
#include <iostream>
class node
public:
int data;
node *p;
};
void add_node()
cin>>temp->data;
temp->p=NULL;
if(head==NULL)
head=t=temp;
else
t->p=temp;
t=t->p;
void showNode ()
for(t=head;t!=NULL;t=t->p)
cout<<t->data<<" ";
}
void countNode (node *head)
int count=0;
for(t=head;t!=NULL;t=t->p)
if(t->data==-1)
count++;
void sort()
for (nodeCtr=13;nodeCtr>=0;nodeCtr--)
temp=head;
t=temp->p;
for(ctr=0;ctr<=nodeCtr;ctr++)
nodeDataCopy= temp->data;
temp->data= t->data;
t->data=nodeDataCopy;
temp=t;
t=t->p;
}
node* middle ()
if (head == NULL)
return NULL;
if (fast != NULL)
return slow;
void binarySearch()
{
node *start = head;
cout<<mid->data;
cin>>temp->data;
temp->p=NULL;
last = last->p;
last->p = temp;
return;
{
// This condition to check whether the
else {
while (pos--) {
if (pos == 0) {
cin>>temp->data;
temp->p=NULL;
temp->p = *current;
*current = temp;
else
current = &(*current)->p;
}
}
if (head == NULL)
return NULL;
head = head->p;
delete temp;
return head;
int main()
add_node();
showNode();
cout<<endl;
countNode(head);
sort();
showNode();
cout<<endl;
binarySearch();
cout<<endl;
append(&head);
showNode();
cout<<endl;
int pos=11;
insertPos(&head, pos);
showNode();
cout<<endl;
head = removeFirstNode(head);
showNode();
Answer:
#include <iostream>
class node
{
public:
int data;
node *p;
};
void add_node()
cin>>temp->data;
temp->p=NULL;
if(head==NULL)
head=t=temp;
else
t->p=temp;
t=t->p;
void showNode ()
for(t=head;t!=NULL;t=t->p)
cout<<t->data<<" ";
}
}
int count=0;
for(t=head;t!=NULL;t=t->p)
if(t->data==-1)
count++;
void sort()
for (nodeCtr=13;nodeCtr>=0;nodeCtr--)
temp=head;
t=temp->p;
for(ctr=0;ctr<=nodeCtr;ctr++)
nodeDataCopy= temp->data;
temp->data= t->data;
t->data=nodeDataCopy;
temp=t;
t=t->p;
node* middle ()
if (head == NULL)
return NULL;
if (fast != NULL)
return slow;
void binarySearch()
{
cout<<mid->data;
cin>>temp->data;
temp->p=NULL;
last = last->p;
last->p = temp;
return;
else {
while (pos--) {
if (pos == 0) {
cin>>temp->data;
temp->p=NULL;
temp->p = *current;
*current = temp;
else
current = &(*current)->p;
}
}
if (head == NULL)
return NULL;
head = head->p;
delete temp;
return head;
node *findNodeInLL()
node* index = 0;
temp = head;
for(int i=1;i<3;i++)
temp = temp->p;
}
index=temp->p;
return index;
t=head;
for(int i=1;i<5;i++)
t= t->p;
temp=t;
delete pos;
t=head;
for(int i=1;i<=2;i++)
t= t->p;
t->p=temp;
int main()
{
add_node();
showNode();
cout<<endl;
countNode(head);
sort();
showNode();
cout<<endl;
binarySearch();
cout<<endl;
append(&head);
showNode();
cout<<endl;
int pos=11;
insertPos(&head, pos);
showNode();
cout<<endl;
head = removeFirstNode(head);
showNode();
cout<<endl;
node* l=findNodeInLL();
deleteNode(l);
showNode();
(d ) Answer:
Output: