排错
帮我改一下 错误//----------------------------------------------------------------------------------
//n个人围成一圈,从第一个人开始报数,凡报到3的人退出圈子,求最后留下的人是原来第几号
//----------------------------------------------------------------------------------
#include<stdio.h>
#include<malloc.h>
//--------------------
typedef struct linknode
{
int data;
struct linknode *next;
}node;
//--------------------
node *creat(int n) //创建链表把1~n个人放进去
{
int i;
node *head, *p, *s;
head = (node *)malloc(sizeof(node));
p = head;
for(i = 1 ; i <= n ; i++)
{
s = (node *)malloc(sizeof(node));
s->data = i;
p->next = s;
p = s;
}
head = head->next;
p->next = head;
p = NULL;
return head;
}
//--------------------
int suanFa() //去掉报3的人
{
int n;
scanf("%d", &n);
node *q1, *q2;
q1 = q2 = creat(n);
while(q1->next->data != q1->data)
{
q1 = q1->next;
q2 = q1->next->next;
q1 = q2;
}
return q->data;
}
//---------------------
int main()
{
printf("%d", suanFa());
return 0;
}
----------------解决方案--------------------------------------------------------
不就是约瑟夫环吗?网上程序有好多类。。。
----------------解决方案--------------------------------------------------------
你看看我这个吧 我不知道我错那里了 给看看啊
----------------解决方案--------------------------------------------------------
哦,原来是找错啊,我以为来秀程序的呢。。。
----------------解决方案--------------------------------------------------------
是啊 我没有那么批扎啊 帮我排一下错哈 谢谢哈 有些地方有不足 没有free() 帮看看哈
----------------解决方案--------------------------------------------------------