c语言 数据结构 约瑟夫环 创建单向循环链表 一直报错 10

#include<stdio.h>#include<stdlib.h>typedefstructLNode{intnum;intkey;structLNode*next;... #include<stdio.h>
#include<stdlib.h>

typedef struct LNode
{
int num;
int key;
struct LNode *next;
}LNode,*LinkList;

void CreateList(LinkList &L);
int ListLength(LNode *L);

int main()
{
int m,n,i;
LNode *L,*p,*q,*r;

scanf("%d%d",&m,&n);
CreateList(L);
p=L->next;
while(ListLength(L)!=1)
{
q=p;
for(i=1;i<m;i++)
{
q=p;
p=p->next;
if(p==L)
{
q=p;
p=p->next;
}
}
printf("%d ",p->num);
m=p->key;
if(p!=q)
{
q->next=p->next;
free(p);
p=q->next;
if(p==L)
p=p->next;
}
else
{
r=L;
while(r->next!=q)
r=r->next;
r->next=q->next;
free(q);
p=r->next;
if(p==L)
p=p->next;

}

}
if(p!=L)
printf("%d\n",p->num);
else
printf("%d\n",p->next->num);
}

void CreateList(LinkList &L)
{
LinkList p,q;
L=(LinkList)malloc(sizeof(LNode));
for(int i=1;i<=n;i++)
{
p=(LinkList)malloc(sizeof(LNode));
scanf("%d",&p->key);
p->num=i;
if(i==1)
L->next=p;
else
q->next=p;
q=p;
if(i==n)
p->next=L;
}
}
int ListLength(LNode *L)
{
int i=0;
LNode *p;
p=L;
while( p->next!=L )
{
i++;
p=p->next;
}
return i;
}
把文件名从.c改成.cpp就好了……
展开
 我来答
shanhuaiyu
2015-10-22 · 超过43用户采纳过TA的回答
知道答主
回答量:116
采纳率:0%
帮助的人:51.5万
展开全部
怎么可能就好了,不敢细看,为何不把调用的写在上面?函数调用参数就有错误,CreateList(&L),L在main函数中是一个指针,接收的就应该是二级指针,而你用地址接收了。
把所有程序写在main函数中估计都比现在短。,也能更清晰。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式