当前位置: 首页 > news >正文

D (1092) : DS循环链表—约瑟夫环(Ver. I - A)

Description

N个人坐成一个圆环(编号为1 - N),从第S个人开始报数,数到K的人出列,后面的人重新从1开始报数。依次输出出列人的编号。 例如:N = 3,K = 2,S = 1。
2号先出列,然后是1号,最后剩下的是3号。
要求使用循环链表实现。

Input

第一行输入t,表示有t个测试用例;

第二行起,每行输入一组数据,包括3个数N、K、S,表示有N个人,从第S个人开始,数到K出列。

(2 <= N <= 10^6,1 <= K <= 10, 1 <= S <= N)

Output

出列的人的编号

Sample

Input
2
13 3 1
3 2 1
Output
3 6 9 12 2 7 11 4 10 5 1 8 13 
2 1 3 

AC代码:

#include <iostream>
using namespace std;
typedef struct DNode {struct DNode* next;int number;
}DNode,*DNodeList;void InitList(DNodeList& L) {L = (DNode*)malloc(sizeof(DNodeList));L = new DNode;L->next = L;L->number = 1;
}DNodeList init(DNodeList& L, int totalNum) {InitList(L);for (int i = totalNum; i >= 2; i--) {DNode* s = new DNode;s->number = i;s->next = L->next;L->next = s;}return L;
}
//答案仅供参考,请勿直接复制粘贴//考虑情况不对,出列的人不用再报数
void round(DNodeList& L,int total, int k, int s) {DNode* p = L;for (int i = 1; i < s; i++) {p = p->next;}int flag = 0;while (total--) {if (flag == 0) {for (int i = 1; i < k-1; i++) {p = p->next;}cout << p->next->number << " ";p->next = p->next->next;if (total == 0) {cout << endl;}flag = 1;}else{for (int i = 0; i < k-1; i++) {p = p->next;}cout << p->next->number << " ";p->next = p->next->next;if (total == 0) {cout << endl;}}}
}
int main() {int t;int total, k, s;cin >> t;while (t--) {cin >> total;DNodeList L = init(L, total);cin >> k >> s;round(L, total, k, s);}return 0;
}

http://www.lryc.cn/news/185586.html

相关文章:

  • Python爬虫(二十二)_selenium案例:模拟登陆豆瓣
  • 1. Flink程序打Jar包
  • 水波纹文字效果动画
  • 【1.1】神经网络:关于神经网络的介绍
  • java项目中git的.ignore文件设置
  • 11.3 读图举例
  • 黑马JVM总结(二十八)
  • 2023年DDoS攻击发展趋势的分析和推断
  • RT-Thread 内存管理(学习二)
  • 怎么修改jupyter lab 的工作路径而不是直接再桌面路径打开
  • 高精度NTP时钟服务器(时间同步服务器)技术方案探讨
  • LFU 缓存 -- LinkedHashSet
  • 用IDEA操作数据库--MySQL
  • 扫雷游戏的递归解法
  • java练习 day5
  • 腾讯云轻量和CVM有啥区别?怎么选择服务器配置?
  • 服务器or虚拟机安装SSH和虚拟机or服务器设置远程服务权限
  • Sentinel入门
  • Mac解压缩软件BetterZip免费版注册码下载
  • 在win10里顺利安装了apache2.4.41和php7.4.29以及mysql8.0.33
  • 云服务仿真:完全模拟 AWS 服务的本地体验 | 开源日报 No.45
  • css实现不规则图片文字环绕效果
  • Day-05 CentOS7.5 安装 Docker
  • 激光雷达:自动驾驶的眼睛
  • Scratch3.0下载
  • 多功能频率计周期/脉宽/占空比/频率测量verilog,视频/代码
  • img标签src动态绑定资源失败问题
  • 【自学笔记】网络安全——黑客技术
  • Rust 技术文档及详细使用命令
  • 建立HTTP代理IP池的技术和工具支持