鱼C论坛

 找回密码
 立即注册
查看: 2236|回复: 2

[已解决]这个题怎么做啊

[复制链接]
发表于 2023-10-27 22:20:30 | 显示全部楼层
这个问题可以使用循环链表来解决。首先,我们可以创建一个包含 m 个节点的循环链表,每个节点表示一个人,并使用编号来标识每个节点。

然后,我们可以从第一个人开始,依次报数并移动到下一个人。当报数达到 n 时,我们将当前节点从链表中删除,然后继续从下一个节点开始报数。重复这个过程,直到只剩下最后一个节点为止。

以下是一个可能的 C++ 实现:
  1. #include <iostream>
  2. using namespace std;
  3. struct Node {
  4.     int value;
  5.     Node* next;
  6. };
  7. void josephus(int m, int n) {
  8.     // 创建循环链表,编号从1到m
  9.     Node* head = new Node{1, nullptr};
  10.     Node* prev = head;
  11.     for (int i = 2; i <= m; i++) {
  12.         Node* newNode = new Node{i, nullptr};
  13.         prev->next = newNode;
  14.         prev = newNode;
  15.     }
  16.     prev->next = head;  // 将链表闭合成循环
  17.     Node* current = head;
  18.     while (current->next != current) {
  19.         // 报数n,找到要出圈的节点的前一个节点
  20.         for (int i = 1; i < n - 1; i++) {
  21.             current = current->next;
  22.         }
  23.         // 删除要出圈的节点
  24.         Node* toRemove = current->next;
  25.         cout << toRemove->value << endl;
  26.         current->next = toRemove->next;
  27.         delete toRemove;
  28.         // 移动到下一个节点,继续报数
  29.         current = current->next;
  30.     }
  31.     // 输出最后一个出圈的人的编号
  32.     cout << current->value << endl;
  33.     // 释放内存,删除链表
  34.     delete current;
  35. }
  36. int main() {
  37.     int m, n;
  38.     cin >> m >> n;
  39.     josephus(m, n);
  40.     return 0;
  41. }
复制代码

这段代码使用了循环链表来模拟围成圈的人,并根据 n 的值进行报数和出圈操作。最后,依次输出出圈的人的编号。请注意,上述代码仅为示例,可以根据需要进行修改和完善。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-10-20 03:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表