63,590
社区成员




#include<iostream>
using namespace std;
struct dot
{
int a;
dot* c;
};
main()
{
int size;
cout<<"请输入数组长度: \n";
con>>size;
dot* a1=new dot[size];
for(int i=0;i<(size-1);i++)
a1[i].c=a1+1+i;//这里是把a1[i].c指向数组的偏移量为i的地址吗?
a1[size-1].c=NULL;
for(int i=0;i<size;i++)
a1[i].a=i*2;
dot*c1=a1;
whlie(c1!=NULL)
{ cout<<c1->a;
c1=c1->c;//这里是把指针指向下一个地址?怎么解释哦?
}
}
a1[i].c=a1+1+i;//这里是把a1[i].c指向数组的偏移量为i的地址吗?
a1[i].c指向了a1[1+i]
c1=c1->c;//这里是把指针指向下一个地址?怎么解释哦?
c1指向了c1->c,也就是遍历指向下个需要cout的c1
#include<iostream>
using namespace std;
struct dot
{
int a;
dot* c; //写成dot *next,好理解一些
};
main()
{
int size;
cout<<"请输入数组长度: \n";
con>>size;
dot* a1=new dot[size];
for(int i=0;i<(size-1);i++)
a1[i].c=a1+1+i;//就是组成一个链表,因为开辟的数组是相连的,所以让第一个指向第二个,第二个指向第三个
a1[size-1].c=NULL;
for(int i=0;i<size;i++)
a1[i].a=i*2;
dot*c1=a1;
whlie(c1!=NULL)
{ cout<<c1->a;
c1=c1->c;//因为已经组成链表了,你就想成链表就行了
}
}