Polynomial is a sum of terms where each term has a form of exponent, variable
and co-efficient. An Abstract data Type Polynomial is the one that shows various
operations that can be performed on polynomials.
In data structures, a polynomial as an Abstract Data Type (ADT) is a way to represent and manipulate polynomials in a
computer program. It typically includes operations for adding, subtracting, multiplying, and evaluating polynomials.
Here’s a brief overview:
Definition: A polynomial ADT consists of a collection of terms where each term has a coefficient and an
exponent. The polynomial is usually represented as a list of these terms.
Structure: The terms can be stored in various ways, such as in an array or a linked list. Each term is a pair of a
coefficient and an exponent. For example, the term ( 3x^2 ) has a coefficient of 3 and an exponent of 2.
Operations: Common operations on a polynomial ADT include:
o Addition: Combining two polynomials by adding the coefficients of terms with the same exponent.
o Multiplication: Multiplying two polynomials which involves multiplying each term of one polynomial
with every term of the other and combining like terms.
o Evaluation: Computing the value of the polynomial for a given value of the variable.
o Degree: Returning the highest exponent in the polynomial.
Here’s a simple C structure for a term in a polynomial represented using a linked list:
typedef struct Pnode {
float coef; // Coefficient of the term
int exp; // Exponent of the term
struct Pnode *next; // Pointer to the next term
} p;
Advantages of using a linked list over an array include:
Only one pointer is needed to point to the first term of the polynomial.
No prior estimation of the number of terms is required, allowing for a more flexible and space-efficient
representation.
Insertion and deletion operations can be carried out easily without moving data.
Disadvantages include:
1
Random access to terms is not possible; one must always traverse from the start node .
For example, to represent the polynomial ( 3x^3 + 2x^2 + x ), you would create a linked list where each node contains
the coefficient and exponent of each term, linked in descending order of exponents1.
This ADT allows for efficient manipulation of polynomials, especially when dealing with operations that involve multiple
terms and varying degrees2
A polynomial is a mathematical expression involving a sum of powers in one or more variables multiplied by
coefficients. In computer science, we can represent a polynomial as an Abstract Data Type (ADT) in a data structure.
Here is a simple example of a polynomial:
P(x) = 5x^3 + 3x^2 - 2x + 1
This polynomial can be represented as an ADT in a data structure. The most common data structure used for this
purpose is a linked list where each node represents a term of the polynomial.
linked list
A linked list is a linear data structure where each element is a separate object, known as a node.
Each node contains two fields: data and a reference (link) to the next node in the sequence.
key points about linked lists:
1. Node Structure: Each node of a linked list contains two elements: data and a reference to the next node. The
data element can contain a value of any data type. The reference is a pointer that points to the next node in the
list.
class Node
{ int data; // can be any type Node next; }
2. Head: The first node of the linked list is referred to as the head. If the linked list is empty, the head is a null
reference.
3. Types of Linked Lists: There are three types of linked lists: singly linked lists, doubly linked lists, and circular
linked lists. In a singly linked list, each node points to the next node. In a doubly linked list, each node points to both the
next node and the previous node. In a circular linked list, the last node points back to the first node.
4. Basic Operations: The basic operations provided by a linked list data structure are:
1. Insertion: Adds an element at the beginning, end, or any given position of the linked list.
2. Deletion: Removes an element from the beginning, end, or any given position of the linked list.
3. Traversal: Accesses each element of the linked list starting from the head, and performs some action.
4. Searching: Searches for an element using the given property.
5. Update: Updates an existing element of the linked list.
5. Advantages of Linked Lists: They are dynamic data structures, which can allocate the needed memory in run-
time. Very efficient if we want to manipulate the first elements. Easy implementation of stacks and queues.
6. Disadvantages of Linked Lists: Waste of memory due to the reference field. Nodes in a linked list must be read
in order from the beginning as linked lists have sequential access.
7. Applications of Linked Lists: Linked lists are used in many applications where
Dynamic memory allocation is required.
They are used in stacks, queues, graphs, and hash tables.
They are also used in the implementation of advanced data structures like Fibonacci heaps.
Construction of linked list
o Linked List can be defined as collection of objects called nodes that are randomly stored in the memory.
o A node contains two fields i.e. data stored at that particular address and the pointer which contains the address
of the next node in the memory.
o The last node of the list contains pointer to the null.
Uses of Linked List
o The list is not required to be contiguously present in the memory. The node can reside any where in the memory
and linked together to make a list. This achieves optimized utilization of space.
o list size is limited to the memory size and doesn't need to be declared in advance.
o Empty node can not be present in the linked list.
o We can store values of primitive types or objects in the singly linked list.
Why use linked list over array?
Till now, we were using array data structure to organize the group of elements that are to be stored individually in the
memory. However, Array has several advantages and disadvantages which must be known in order to decide the data
structure which will be used throughout the program.
Array contains following limitations:
1. The size of array must be known in advance before using it in the program.
2. Increasing size of the array is a time taking process. It is almost impossible to expand the size of the array at run
time.
3. All the elements in the array need to be contiguously stored in the memory. Inserting any element in the array
needs shifting of all its predecessors.
Types of linked list
1. Singly linked list or One way chain
Singly linked list can be defined as the collection of ordered set of elements.
The number of elements may vary according to need of the program.
A node in the singly linked list consist of two parts: data part and link part. Data part of the node stores actual
information that is to be represented by the node
the link part of the node stores the address of its immediate successor.
Backward Skip 10sPlay Video Forward Skip 10s
One way chain or singly linked list can be traversed only in one direction. In other words, we can say that each
node contains only next pointer, therefore we can not traverse the list in the reverse direction.
Consider an example where the marks obtained by the student in three subjects are stored in a linked list as
shown in the figure.
2. Doubly linked list
Doubly linked list is a complex type of linked list in which a node contains a pointer to the previous as well as the next
node in the sequence. Therefore, in a doubly linked list, a node consists of three parts: node data, pointer to the next
node in sequence (next pointer) , pointer to the previous node (previous pointer). A sample node in a doubly linked list is
shown in the figure.
A doubly linked list containing three nodes having numbers from 1 to 3 in their data part, is shown in the following
image.
In C, structure of a node in doubly linked list can be given as :
1. struct node
2. {
3. struct node *prev;
4. int data;
5. struct node *next;
6. }
The prev part of the first node and the next part of the last node will always contain null indicating end in each direction.
In a singly linked list, we could traverse only in one direction, because each node contains address of the next node and
it doesn't have any record of its previous nodes. However, doubly linked list overcome this limitation of singly linked list.
Due to the fact that, each node of the list contains the address of its previous node, we can find all the details about the
previous node as well by using the previous address stored inside the previous part of each node.