当前位置: 代码迷 >> C语言 >> 排错
  详细解决方案

排错

热度:361   发布时间:2008-04-11 15:59:41.0
排错
帮我改一下 错误

//----------------------------------------------------------------------------------
//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;
}
搜索更多相关的解决方案: int  node  include  struct  链表  

----------------解决方案--------------------------------------------------------
不就是约瑟夫环吗?网上程序有好多类。。。
----------------解决方案--------------------------------------------------------
你看看我这个吧 我不知道我错那里了 给看看啊
----------------解决方案--------------------------------------------------------
哦,原来是找错啊,我以为来秀程序的呢。。。
----------------解决方案--------------------------------------------------------
是啊 我没有那么批扎啊 帮我排一下错哈 谢谢哈 有些地方有不足 没有free() 帮看看哈
----------------解决方案--------------------------------------------------------
  相关解决方案