473,396 Members | 1,860 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,396 software developers and data experts.

Linked list

struct node *insert(struct node *p);
void *add (struct node *a,struct node *b);
#include<stdio.h>
#include<conio.h>
#include<alloc.h>
struct node
{
int cof,ex,ey,ez;
struct node *link;

};
void main ()
{
struct node *a,*b,*q;
int i,ter1,ter2;
clrscr();
printf("\n\nNo of terms you want to enter for first polynomial");
scanf("%d",&ter1);
printf("\n\nNo of terms you want to enter for second polynomial");
scanf("%d",&ter2);
a=NULL;
b=NULL;
for(i=0;i<ter1;i++)
{
a=insert(a);
}
for(i=0;i<ter2;i++)
{
b=insert(b);
}
printf("\n\nFor first polynomial");
q=a;
for(i=0;i<ter1;i++)
{
printf("\n\nEnter the coffecient & exponent of x,y,z of %d term :",i+1);
scanf("%d%d%d%d",&q->cof,&q->ex,&q->ey,&q->ez);
q=q->link;
}
printf("\n\nFor second polynomial");
q=b;
for(i=0;i<ter2;i++)
{
printf("\n\nEnter the coffecient & exponent of x,y,z of %d term :",i+1);
scanf("%d%d%d%d",&q->cof,&q->ex,&q->ey,&q->ez);
q=q->link;
}

printf("\n\nFirst polynomial is :\n\n");
q=a;
for(i=0;i<ter1;i++)
{
printf("%d(X^%dY^%dZ^%d) + ",q->cof,q->ex,q->ey,q->ez);
q=q->link;
}

printf("\n\nSecond polynomial is :\n\n");
q=b;
for(i=0;i<ter2;i++)
{
printf("%d(X^%dY^%dZ^%d) + ",q->cof,q->ex,q->ey,q->ez);
q=q->link;
}

add(a,b);
getch();
}

struct node *insert(struct node *p)
{
struct node *temp;
if(p==NULL)
{
temp=(struct node*)malloc(sizeof(struct node));
p=temp;
temp->link=NULL;
}
else
{
temp=p;
temp->link=(struct node*)malloc(sizeof(struct node));
temp=temp->link;
temp->link=NULL;
}
return(p);
}

void *add(struct node *a,struct node *b)
{
struct node *q,*p,*c,*temp;
int i=0,j;
p=a;
q=b;
c=NULL;
while(p->link!=NULL && q->link!=NULL)
{
if(p->ex==q->ex && p->ey==q->ey && p->ez==q->ez)
{
c=insert(c) ;
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=p->cof + q->cof;
temp->ex=p->ex;
temp->ey=p->ey;
temp->ez=p->ez;
temp->link=NULL;
i=i+1;
p=p->link;
q=q->link;
}
else
{
c=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=p->cof;
temp->ex=p->ex;
temp->ey=p->ey;
temp->ez=p->ez;
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
c=insert(c);
temp->link=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=q->cof;
temp->ex=q->ex;
temp->ey=q->ey;
temp->ez=q->ez;
i=i+2;
}
}
if(p->link==NULL && q->link!=NULL)
{
if(p->ex==q->ex && p->ey==q->ey && p->ez==q->ez)
{
c=insert(c) ;
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->link=insert(c);
temp->cof=p->cof + q->cof;
temp->ex=p->ex;
temp->ey=p->ey;
temp->ez=p->ez;
temp->link=NULL;
i=i+1;
q=q->link;
}
else
{
c=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->link=insert(c);
temp=temp->link;
temp->cof=p->cof;
temp->ex=p->ex;
temp->ey=p->ey;
temp->ez=p->ez;
c=insert(c);
temp->link=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=q->cof;
temp->ex=q->ex;
temp->ey=q->ey;
temp->ez=q->ez;
i=i+2;
q=q->link;
}
do
{
temp->link=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=q->cof;
temp->ex=q->ex;
temp->ey=q->ey;
temp->ez=q->ez;
i=i+1;
q=q->link;
}while(q->link!=NULL);
}
if(q->link==NULL)
{
if(p->ex==q->ex && p->ey==q->ey && p->ez==q->ez)
{
c=insert(c) ;
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=p->cof + q->cof;
temp->ex=p->ex;
temp->ey=p->ey;
temp->ez=p->ez;
temp->link=NULL;
i=i+1;
p=p->link;
}
else
{
c=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=p->cof;
temp->ex=p->ex;
temp->ey=p->ey;
temp->ez=p->ez;
c=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=q->cof;
temp->ex=q->ex;
temp->ey=q->ey;
temp->ez=q->ez;
i=i+2;
p=p->link;
}
do
{
c=insert(c);
temp=c;
while(temp->link!=NULL)
{
temp=temp->link;
}
temp->cof=p->cof;
temp->ex=p->ex;
temp->ey=p->ey;
temp->ez=p->ez;
i=i+1;
}while(p->link!=NULL);
}
printf("\n\n");
temp=c;
for(j=0;j<i;j++)
{
printf("%d(X^%dY^%dZ^%d)+",temp->cof,temp->ex,temp->ey,temp->ez);
temp=temp->link;
}

}

Help me to solve this question
Sep 16 '06 #1
2 4713
I think you are storing each term of the polynomial in a new node in a linked list. By using the below function you are creating the nodes for storing the terms of the polynomial.

struct node *insert(struct node *p)
{
struct node *temp;
if(p==NULL)
{
temp=(struct node*)malloc(sizeof(struct node));
p=temp;
temp->link=NULL;
}
else
{
temp=p;
temp->link=(struct node*)malloc(sizeof(struct node));
temp=temp->link;
temp->link=NULL;
}
return(p);
}

When you call this function for first two times, it works properly. But third time onwards, it will not work.

Let us assume that you require 4 nodes to store the terms of the polynomial and list is created upto the second node. When the above function is called for creating the third node it does the following...

1. The execution control will go the else portion and assign the head of the list to temp variable.

2. Now you are creating another node in the link portion where already a node exists. So the new node will overwrite this portion and you will ultimately get two nodes irrespective of the number of calls you made to this function.

So change the function to..........

struct node *insert(struct node *p)
{
if(p==NULL)
{
p=(struct node*)malloc(sizeof(struct node));
p->link=NULL;
}
else
{
p->link=insert(p->link);
}
return(p);
}


OR


struct node *insert(struct node *p)
{
struct node *temp;
if(p==NULL)
{
temp=(struct node*)malloc(sizeof(struct node));
p=temp;
temp->link=NULL;
}
else
{
temp=p;

while(temp->link != NULL) /* This loop will take you to the last node */
temp=temp->link;

temp->link=(struct node*)malloc(sizeof(struct node));
temp=temp->link;
temp->link=NULL;
}
return(p);
}
Sep 16 '06 #2
Thank you for pointing out the error
I want to multiply these two polynomial
Code for multipliction is

void *multiply(struct node *a,struct node *b,int ter1,int ter2)
{
struct node *p,*q,*c,*temp;
int i,j;
c=NULL;
p=a;
q=b;
for(i=0;i<ter1*ter2;i++)
{
c=insert(c);

}
temp=c;
for(i=0;i<ter1;i++)
{
for(j=0;j<ter2;j++)
{
temp->cof=p->cof*q->cof;
temp->ex=p->ex+q->ex;
temp->ey=p->ey+q->ey;
temp->ez=p->ez+q->ez;
temp=temp->link;
q=q->link;
}
q=b;
temp=temp->link;
p=p->link;
}
printf("\n\n ");
temp=c;
for(i=0;i<(ter1*ter2);i++)
{
printf("%d(X^%dY^%dZ^%d)+",temp->cof,temp->ex,temp->ey,temp->ez);
temp=temp->link;
}
}
please help to solve this.
Sep 20 '06 #3

Sign in to post your reply or Sign up for a free account.

Similar topics

11
by: C++fan | last post by:
Suppose that I define the following class: class example_class{ public: example_class(); void funtion_1(); void function_2(); protected:
5
by: Dream Catcher | last post by:
1. I don't know once the node is located, how to return that node. Should I return pointer to that node or should I return the struct of that node. 2. Also how to do the fn call in main for that...
10
by: Kent | last post by:
Hi! I want to store data (of enemys in a game) as a linked list, each node will look something like the following: struct node { double x,y; // x and y position coordinates struct enemy...
6
by: Steve Lambert | last post by:
Hi, I've knocked up a number of small routines to create and manipulate a linked list of any structure. If anyone could take a look at this code and give me their opinion and details of any...
12
by: Eugen J. Sobchenko | last post by:
Hi! I'm writing function which swaps two arbitrary elements of double-linked list. References to the next element of list must be unique or NULL (even during swap procedure), the same condition...
12
by: joshd | last post by:
Hello, Im sorry if this question has been asked before, but I did search before posting and couldnt find an answer to my problem. I have two classes each with corresponding linked lists, list1...
51
by: Joerg Schoen | last post by:
Hi folks! Everyone knows how to sort arrays (e. g. quicksort, heapsort etc.) For linked lists, mergesort is the typical choice. While I was looking for a optimized implementation of mergesort...
1
by: theeverdead | last post by:
Ok I have a file in it is a record of a persons first and last name. Format is like: Trevor Johnson Kevin Smith Allan Harris I need to read that file into program and then turn it into a linked...
0
by: Atos | last post by:
SINGLE-LINKED LIST Let's start with the simplest kind of linked list : the single-linked list which only has one link per node. That node except from the data it contains, which might be...
7
by: QiongZ | last post by:
Hi, I just recently started studying C++ and basically copied an example in the textbook into VS2008, but it doesn't compile. I tried to modify the code by eliminating all the templates then it...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.