数据结构(c语言)用线性表实现约瑟夫问题,求大佬帮看看怎么实现下面的代码

#include
#include
#include

#define TRUE 1
#define FALSE 0
#define OK 1
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2
typedef int Status;

typedef int ElemType;

typedef struct LNode

{
ElemType data;
struct LNode *next;
} LNode, * LinkList;
int yue(int m, int n)
{
//head指向不带头节点的循环单链表
LinkList head = NULL, cur, p;
int i, j;

//生成第一个节点
head = (LinkList) malloc(sizeof(LNode));
head->data = 1;
head->next = head;

//使用尾插法按顺序生成节点
//在此处嵌入你的代码

//约瑟夫开始
cur = head;
//循环m-1次

for(i = 1; i < m; i++)

{
//每次循环开始计数
//在此处嵌入你的代码
}
//返回最后剩下的节点数据域,即为最后剩下的人
return cur->data;
}

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 以帮助更多的人 ^-^