CircleLinkList(循环链表)
尾插法和循环链表。
#include <stdio.h>
#include <stdlib.h> typedef struct CircleLinkList
{
int data;
struct CircleLinkList * next;
}circleLinkList; int main()
{
circleLinkList * h, * r, * s;
circleLinkList * L;
int n, num; printf("请输入参与约瑟夫环的总人数及淘汰者编号:");
scanf("%d %d",&n,&num); h = (circleLinkList *)malloc(sizeof(circleLinkList));
r = h;
for(int i = 0; i < n; i++) // 尾插法建立链表
{
s = (circleLinkList *)malloc(sizeof(circleLinkList));
s -> data = i + 1; // 为参与人员编号
r -> next = s; // 中间过程分配的空间插到尾指针后面
r = s;
} r -> next = NULL;
L = h -> next;
while(L)
{
printf("%d ",L -> data);
L = L -> next;
} r -> next = h -> next;
L = h -> next;
while(L -> next != L)
{
for(int j = 1; j < num - 1; j++)
{
L = L -> next;
}
L -> next = L -> next -> next;
L = L -> next;
}
puts("\n最终胜利者:");
printf("%d\n",L -> data); return 0;
}
Output:

本段代码其本质都是用第一段代码中的主要方法 尾插法 来建立链表的):
#include <stdio.h>
#include <stdlib.h> typedef struct CircleLinkList
{
int data;
struct CircleLinkList * next;
}circleLinkList; int main()
{
circleLinkList * h = NULL, * p, * q;
int n , num; printf("请输入参与人数及淘汰编号:");
scanf("%d %d",&n,&num); for(int i = 0; i < n; i++)
{
p = (circleLinkList *)malloc(sizeof(circleLinkList));
if(h == NULL)
h = p;
else
q -> next = p;
p -> data = i + 1;
p -> next = NULL;
q = p;
} q -> next = h;//循环条件 while(h != h -> next)
{
for(int i = 1; i < num - 1; i++)
h = h -> next;
h -> next = h -> next -> next;
h = h -> next;
}
puts("最终胜利者:");
printf("%d\n",h -> data); return 0;
}
CircleLinkList(循环链表)的更多相关文章
- 【数据结构】循环链表&&双向链表详解和代码实例
喜欢的话可以扫码关注我们的公众号哦,更多精彩尽在微信公众号[程序猿声] 01 循环链表 1.1 什么是循环链表? 前面介绍了单链表,相信大家还记得相关的概念.其实循环链表跟单链表也没有差别很多,只是在 ...
- 循环链表C语言实现
按照单链表的设计,稍加改动.和单向链表不一样的地方,头节点不指向NULL,而是指向自己head 循环链表的判满 1)判断next是不是头结点,2)判断size /* * CycleLinkList.h ...
- C语言- 基础数据结构和算法 - 循环链表
听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可 ...
- java程序设计之循环链表
照例来说点废话,愿自己生一颗温柔细腻的心,这样女朋友也许一个眼神,一个微笑,我就知道如何做,可惜内心与外表一样粗糙,这一生有幸认识她,愿天下有情人终成眷属. 循环链表,顾名思义循环就好了,所以建一个线 ...
- 单链表、循环链表的JS实现
数据结构系列前言: 数据结构作为程序员的基本知识,需要我们每个人牢牢掌握.近期我也展开了对数据结构的二次学习,来弥补当年挖的坑...... 当时上课的时候也就是跟着听课,没有亲自实现任何一种数据结 ...
- 双向链表、双向循环链表的JS实现
关于链表简介.单链表.单向循环链表.JS中的使用以及扩充方法: 单链表.循环链表的JS实现 关于四种链表的完整封装: https://github.com/zhuwq585/Data-Structu ...
- JAVA 链表操作:循环链表
主要分析示例: 一.循环链表简述 二.单链表循环链表 三.双链表循环链表 一.循环链表简述 循环链表即链表形成了一个循环的结构,尾节点不再指向NULL,而是指向头节点HEAD,此时判定链表的结束是尾节 ...
- Have Fun with Numbers及循环链表(约瑟夫问题)
1. 循环链表(约瑟夫问题) https://github.com/BodhiXing/Data_Structure 2. Have Fun with Numbers https://pta.pate ...
- javascript中使用循环链表实现约瑟夫环问题
1.问题 传说在公元1 世纪的犹太战争中,犹太历史学家弗拉维奥·约瑟夫斯和他的40 个同胞被罗马士兵包围.犹太士兵决定宁可自杀也不做俘虏,于是商量出了一个自杀方案.他们围成一个圈,从一个人开始,数到第 ...
随机推荐
- 水题Eating Soup
A. Eating Souptime limit per test1 secondmemory limit per test256 megabytesinputstandard inputoutput ...
- android .9背景图作为TextView背景时文字无法居中问题
问题产生原因: .9图黑色边框绘制伸缩区域有问题,重叠的最大区域是TextView文字所能显示的区域 如下图所示,横向和纵向最大重叠部分就是文字可显示部分,这个图作为背景后文字整体偏下,无法上下居中对 ...
- C语言随笔5:函数、函数指针
函数 C语言中函数参数传递时,将实参的值拷贝到函数参数的存储区中.这种传递参数的方式称为按值传递. 函数不会访问实参本身,访问的是函数存储在栈区的副本,不会改变实参.函数凋用结束,函数在栈区的内容释放 ...
- HADOOP_SECURE_DN_USER has been replaced by HDFS_DATANODE_SECURE_USER
这个问题可能是我第一个遇到吧,hadoop启动时WARNING: HADOOP_SECURE_DN_USER has been replaced by HDFS_DATANODE_SECURE_USE ...
- 记录一下自己搭建springboot+mybatis+druid 多数据源的过程
前言 上次的一个项目(springboot+mybatis+vue),做到后面的时间发现需要用到多数据源.当时没有思路..后来直接用了jdbc来实现.这几天不是很忙,所以决定自己再搭建一次.不多说, ...
- vue+axios安装
Axios是一个基于promise的HTTP库,可以用在浏览器和node.js中. 安装方式: 1.使用cdn <script src="https://unpkg.com/axios ...
- Python 树莓派 引脚
#!/usr/bin/python3 import RPi.GPIO as GPIO import time GPIO.setmode(GPIO.BCM) GPIO.setup(18, GPIO.OU ...
- ACM的探索之Everything Is Generated In Equal Probability(这真的是很有趣的话语丫!)
---------------------------------------步履不停,奋勇前进! ------------------------难度真的是蛮大丫!后序补充!
- C语言创建共享库(动态库)步骤
C语言创建共享库(动态库)步骤: 创建sth.c,共享库源文件: //sth.c库源程序 unsigned long long sth(unsigned int x, unsigned int y) ...
- mongodb的一些操作
插入: db.inventory.insert( { _id: 10, type: "misc", item: "card", qty: 15 } ) db.i ...