打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
约瑟夫问题,丢手绢问题
#include <stdio.h>
#include <stdlib.h>


typedef struct node
{
int data;
struct node* next;
}cLinkList;

int main()
{
cLinkList *head, *p, *s, *temp;
int n, k;
int i = 1;
printf("Please enter the total number n:\n");
scanf("%d", &n);
printf("Please enter the key value:\n");
scanf("%d", &k);
head = (cLinkList *)malloc(sizeof(cLinkList));
p = head;
p->next = p;
p->data = i;
for (i = 2; i <= n; i++)
{
s = (cLinkList *)malloc(sizeof(cLinkList));
s->data = i;
s->next = p->next;
p->next = s;
p = s;
}
p = head;
while (n--)
{
for (i = 1; i < k - 1; i++)
{
p = p->next;//p指向了k-1项
}
printf("%d->", p->next->data);
temp = p->next;
p->next = temp->next;
free(temp);
p = p->next;
}
printf("Done!\n");
return 0;
}
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
详解双向链表的基本操作(C语言)
链表(数据结构)
单链表
C语言链表的基本操作:增、删、遍历、翻转
C语言实现时间片轮转法的cpu调度模拟
C语言实现双向链表
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服