请教一道C语言编程题,麻烦帮我看一下哪儿错了

structlink{intdata;structlink*next;}main(){inti,n;structlinka[101],*p,*pr;scanf("%d",... struct link
{
int data;
struct link *next;
}
main()
{
int i,n;
struct link a[101],*p,*pr;

scanf("%d",&n);
for(i=1;i<n;i++)
{
a[i].next=&a[i+1];
}
a[n+1].next=&a[1];
for(i=1;i<=n;i++)
{
a[i].data=i;
}
p=&a[1];
do{
p=p->next;
pr=p->next;
p->next=pr->next;
p=pr->next;
}while(p->next=p)
printf("%d",p->data);
}
忘了写了,这是一道问题:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报 数),凡报到3的人退出圈子。问最后留下的是原来的第几号
好吧,我在结构体定义和WHILE循环那里忘加了分号,除此之外呢,还是运行的不对啊
晕,初学C,又把==写成=了
展开
 我来答
shaoshuai326
2011-11-13 · TA获得超过151个赞
知道答主
回答量:113
采纳率:0%
帮助的人:67.3万
展开全部
你while循环里面每回删掉一个节点,不是报到3删除一个,所以缺少一个计算器,结果肯定不对,而且while(p->next=p)里面条件总是为真,所以循环不会出来。
追问
我不是每报一个三就跳过他了吗,比如1,2,3,4时,把2指向了4,3不就没了吗
追答
无错误代码如下:
#include
#include
#include

struct link
{
int data;
struct link *next;
};

int main()
{
int i,n;
struct link a[101],*p,*pr;

scanf("%d",&n);
for(i=1;inext;
pr=p->next;
p->next=pr->next;
p=pr->next;
//你退出条件错了
}while(p->next!=p);
printf("%d",p->data);
system("pause");
return 1;
}

补充:这道题可以用数学方法解决,你也可以 看看,还有可以使用数组加标志位的方式来写,不过用链表写的不错,也应该学的不错了。
松林小鼠
2011-11-13
知道答主
回答量:31
采纳率:0%
帮助的人:13.6万
展开全部
题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出
程序源代码:
#define nmax 50
main()
{
int i,k,m,n,num[nmax],*p;
printf("please input the total of numbers:");
scanf("%d",&n);
p=num;
for(i=0;i<n;i++)
 *(p+i)=i+1;
 i=0;
 k=0;
 m=0;
 while(m<n-1)
 {
 if(*(p+i)!=0) k++;
 if(k==3)
 { *(p+i)=0;
 k=0;
 m++;
 }
i++;
if(i==n) i=0;
}
while(*p==0) p++;
printf("%d is left\n",*p);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
班丘晓桐0U
2011-11-13 · TA获得超过446个赞
知道小有建树答主
回答量:739
采纳率:0%
帮助的人:621万
展开全部
struct link
{
int data;
struct link *next;
}; //此处应加分号
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式