博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一道模拟题:改进的Joseph环
阅读量:5892 次
发布时间:2019-06-19

本文共 1622 字,大约阅读时间需要 5 分钟。

题目:改进的Joseph环。一圈人报数,报数上限依次为3,7,11,19,循环进行,直到所有人出列完毕。

思路:双向循环链表模拟。

代码:

1 #include 
2 #include
3 4 #define N 20 5 6 typedef struct node 7 { 8 int id; 9 struct node *next;10 struct node *pre;11 }Node, *pNode;12 13 //双向循环链表的构建14 pNode RingConstruct (int n)15 {16 int i;17 pNode head, p, q;18 head = (pNode)malloc(sizeof(Node));19 head->id = 1;20 p = head;21 for (i = 2; i <= n; i++)22 {23 q = (pNode)malloc(sizeof(Node));24 q->id = i;25 p->next = q;26 q->pre = p;27 p = q;28 }29 p->next = head;30 head->pre = p;31 return head;32 }33 34 //传入报数的次数序号,返回此次报数的上限值35 int boundMachine (int order)36 {37 int boundList[4] = {
3, 7, 11, 19};38 return boundList[(order - 1)%4];39 }40 41 //first为每次报数的第一人,bound为此次报数的上限,返回此次报数的应出列者42 pNode count (pNode first, int bound)43 {44 while (--bound)45 {46 first = first->next;47 }48 return first;49 }50 51 //将currentNode从环中删除,并返回被删除节点的下一节点52 pNode removeNode (pNode currentNode)53 {54 pNode first = currentNode->next;55 if (first != currentNode)56 {57 currentNode->pre->next = first;58 first->pre = currentNode->pre;59 }60 printf("%d ", currentNode->id);61 free(currentNode);62 return first;63 }64 65 int main (int argc, char *argv)66 {67 pNode first, toRemove;68 int i;69 first = RingConstruct(N);70 for (i = 1; i <= N; i++)71 {72 toRemove = count(first, boundMachine(i));73 first = removeNode(toRemove);74 }75 return 0;76 }

当N为20时,出列顺序是:

转载地址:http://clnsx.baihongyu.com/

你可能感兴趣的文章
BeanUtils\DBUtils
查看>>
[转]理解Linux文件系统之inode
查看>>
python模块--os模块
查看>>
linux下单节点oracle数据库间ogg搭建
查看>>
swift三方库
查看>>
POJ NOI0105-42 画矩形
查看>>
Java 数组在内存中的结构
查看>>
《关爱码农成长计划》第一期报告
查看>>
学习进度表 04
查看>>
谈谈javascript中的prototype与继承
查看>>
时序约束优先级_Vivado工程经验与各种时序约束技巧分享
查看>>
minio 并发数_MinIO 参数解析与限制
查看>>
mysql 应用程序是哪个文件夹_Mysql 数据库文件存储在哪个目录?
查看>>
mysql半同步和无损复制_MySQL半同步复制你可能没有注意的点
查看>>
python编译exe用于别的电脑上_Python安装教程(推荐一款不错的Python编辑器)
查看>>
flash back mysql_mysqlbinlog flashback 使用最佳实践
查看>>
hive中如何把13位转化为时间_sqoop1 导入 hive parquet 表中 时间戳调整为日期
查看>>
mysql书外键_[转] mysql 外键(Foreign Key)的详解和实例
查看>>
mysql存储引擎模式_MySQL存储引擎
查看>>
mysql5002_mysql新手进阶02
查看>>