I have a great idea of how to implement an algebra solving/simplfying program, but I need it to have a structure within itself. Here's what I mean:
struct thing {
thing *t1;
thing *t2;
int other;
};
As you can see, the struct uses itself, and therefore cannot define 'thing' until it is finished, making a sort of catch 22. Is there a way to do something like this? All it needs to do is store two pointers to other instances of the same data type and one integer. If it is possible with a class, that would work too.
The code can be completely different, as long as it does what I described or gives an alternate method.
C/C++ - nested objects/structs question?
Well my C is a bit rusty but I know it is officially impossible to declare a structure containing an instance of itself....talk about endless loop! so doubt C++ would allow it either as physically impossible.
Couldn't you make a small array to hold the pointers and int? you could use an ordinary do-while to loop through?
Reply:Pointers to similar structures or classes is a common concept in data structures. This is how things such as linked lists or trees. They have a structure with a pointer the same structure for the next one in the list or the children in the tree. Look up linked list in wikipedia to see what I mean.
Anyways, here is some code demonstrating what you want to do. This is in C, but you can do similar things with classes in C++. I also played with the variables a bit to demonstrate different ways of accessing the data.
#include %26lt;stdio.h%26gt;
//get the compiler to recognize Thing as its own data type
typedef struct Thing Thing;
//define the struct
struct Thing {
Thing *first;
Thing *second;
int val;
};
int main()
{
Thing o1;
Thing o2;
Thing o3;
Thing *p4;
Thing *p5;
Thing *p6;
//dynamicall created Things
p4 = (Thing*)malloc(sizeof(Thing));
p5 = (Thing*)malloc(sizeof(Thing));
p6 = (Thing*)malloc(sizeof(Thing));
o1.first = %26amp;o2;
o1.second = %26amp;o3;
o1.val = 1;
o2.val = 2;
o1.second-%26gt;val = 3; // does same as o3.val = 3
p4-%26gt;first = p5;
p4-%26gt;second = p6;
p4-%26gt;val = 4;
p5-%26gt;val = 5;
p4-%26gt;second-%26gt;val = 6; // does same as p6-%26gt;val = 6;
printf("%d\n", o1.val);
printf("%d\n", o1.first-%26gt;val);//same as printing o2.val
printf("%d\n", o3.val);
printf("%d\n", p4-%26gt;val);
printf("%d\n", p4-%26gt;first-%26gt;val); //same as printing p5-%26gt;val
printf("%d\n", p6-%26gt;val);
//free dynamically created objects
free(p4);
free(p5);
free(p6);
return 0;
}
Reply:first thought : try the 'this' pointer in a class .. might work as such
#include %26lt;iostream%26gt;
using namespace std;
class many
{
public:
int integer1;
many *ptr;
many()
{
integer1 = 0;
ptr = this;
}
};
void main()
{
many o;
cout%26lt;%26lt;o.integer1%26lt;%26lt;endl;
cout%26lt;%26lt;o.ptr-%26gt;integer1%26lt;%26lt;endl;
}
Reply:Use forward class/struct declaration, for example:
struct thing;
struct thing {
thing *t1;
thing *t2;
int other;
};
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment