c语言单向循环链表倒置,C语言单向循环链表解决约瑟夫问题

/*************************************************************************

> File Name: josefu.c

> Author: Baniel Gao

> Mail: createchance@163.com

> Blog: blog.csdn.net/createchance

> Created Time: Thu 19 Dec 2013 03:08:21 PM CST

************************************************************************/

#include

#include

typedef struct josefu

{

int data;

struct josefu *next;

} josefu_list;

josefu_list *josefu_init(int num);

josefu_list *josefu_begin(josefu_list *list, int rule);

josefu_list *josefu_node(int num);

int josefu_free(josefu_list *list);

int main(void)

{

josefu_list *list;

int num, rule;

puts("Please input number and rules: ");

scanf("%d%d", &num, &rule);

list = josefu_init(num);

list = josefu_begin(list, rule);

josefu_free(list);

return 0;

}

josefu_list *josefu_init(int num)

{

int i;

josefu_list *new;

josefu_list *list = josefu_node(1);

for(i = num; i > 1; i--) {

new = josefu_node(i);

new->next = list->next;

list->next = new;

}

return list;

}

josefu_list *josefu_node(int num)

{

josefu_list *p = NULL;

p = (josefu_list *)malloc(sizeof(josefu_list));

p->data = num;

p->next = p;

return p;

}

josefu_list *josefu_begin(josefu_list *list, int rule)

{

int counter;

josefu_list *tmp = NULL;

for(counter = 1; list->next != list; counter++) {

if(counter == rule - 1) {

tmp = list->next;

list->next = tmp->next;

free(tmp);

counter = 0;

josefu_show(list);

}

list = list->next;

}

return list;

}

int josefu_show(josefu_list *list)

{

josefu_list *p = list;

if(list == NULL)

return 0;

do {

printf("%5d",p->data);

p = p->next;

} while(list != p);

putchar('

');

}

int josefu_free(josefu_list *list)

{

free(list);

return 0;

}

运行实例:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值