循环单链表

念言 2013-06-07 07:55:27
LinkedList LinkedListCreat()//尾插法建立带头结点的循环单链表
{
int x,n;
LinkedList p;
L=(LNode *)malloc(sizeof(LNode));
p=(LNode *)malloc(sizeof(LNode));
L->next=NULL;
scanf("%d",&n);
for(x=1;x<=n;x++)
{
p->data=x;
if(L->next==NULL)
{
L->next=p;
p->next=L;
}
else
{
p->next=L->next;
L->next=p;
}

};
return L;
}

输入 5 怎么一直出5555555555555555555555555555555 哪里出错了~~我的12345432123454321....呢
...全文
231 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2013-06-08
  • 打赏
  • 举报
回复
十字链表交换任意两个节点C源代码(C指针应用终极挑战)http://download.csdn.net/detail/zhao4zhong1/5532495
qq453345496 2013-06-07
  • 打赏
  • 举报
回复
该总结自己错在哪里了
念言 2013-06-07
  • 打赏
  • 举报
回复
引用 2 楼 zengzhihao 的回复:
LinkedList LinkedListCreat()//尾插法建立带头结点的循环单链表
{
	int x,n;
	LinkedList p;
    L=(LNode *)malloc(sizeof(LNode));
    	L->next=NULL;
	scanf("%d",&n);
    for(x=1;x<=n;x++)
	{
	p=(LNode *)malloc(sizeof(LNode));   
        p->data=x;
       if(L->next==NULL)
	   {
          L->next=p;
          p->next=L;
	   }
	   else
	   {
          p->next=L->next;
          L->next=p;
	   }

    };
	return L;
}
soga~~~~
bewinged 2013-06-07
  • 打赏
  • 举报
回复
LinkedList LinkedListCreat()//尾插法建立带头结点的循环单链表
{
	int x,n;
	LinkedList p;
    L=(LNode *)malloc(sizeof(LNode));
    	L->next=NULL;
	scanf("%d",&n);
    for(x=1;x<=n;x++)
	{
	p=(LNode *)malloc(sizeof(LNode));   
        p->data=x;
       if(L->next==NULL)
	   {
          L->next=p;
          p->next=L;
	   }
	   else
	   {
          p->next=L->next;
          L->next=p;
	   }

    };
	return L;
}
Carl_CCC 2013-06-07
  • 打赏
  • 举报
回复
你不停的插入节点都不停的分配内存啊。 你应该把p=(LNode *)malloc(sizeof(LNode));放for循环里面去

70,023

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧