3 solutions
-
0
这道题是一道经典的循环链表
#include <bits/stdc++.h> //循环链表 using namespace std; const int maxn = 1e3 + 5; int id[maxn]; typedef struct Node { int value; Node *next; }NodeList; int main(void) { int n, m; cin >> n >> m; NodeList *head, *last = NULL; NodeList *node; for (int i = 1; i <= n; i++) { node = (NodeList*)malloc(sizeof(NodeList)); node->value = i; if (i == 1) { head = node; last = node; }else { last->next = node; last = node; } } node->next = head; last = node; int i = 1; int cnt = 1; while (head->next != head) { if (i == m) { NodeList *p = head; last->next = head->next; id[p->value] = cnt; cnt ++; free(p); i = 1; head = last->next; }else { last = head; head = head->next; i ++; } } for (int i = 1; i <= n; i++) { if (!id[i]) id[i] = n; cout << id[i] << ' '; } return 0;
}
-
0
约瑟夫环 经典题了,用 队列 随别 虐杀。数组的话 也可以。
#include <iostream> #include <queue> using namespace std; int arr[1005]; // 到底是 第几次 自杀的 都存在 这里 int main(void) { int n, k;// n 个 人,报数到 k 就会自杀 cin >> n >> k; queue<int> que; for (int i = 1; i <= n; ++i) { que.push(i); // 先把这些人 都添加到 队列里 } int ans = 0;// 记录是第几个 出去的 int jilu = 0; // 记录 数到 几了 while (que.size()) { int id = que.front();// 编号 que.pop(); jilu++; if (jilu != k) { que.push(id); } else { ans++; arr[id] = ans; jilu = 0; } } for (int i = 1; i <= n; ++i) { cout << arr[i] << " "; } return 0; }
-
0
#include <stdio.h> #include <algorithm> #include <math.h> #include <vector> #include <iostream> #include <string.h> #include <queue> using namespace std; int n,k; queue<int> q; int a[1005]; int main() { scanf("%d%d",&n,&k); for(int i=1; i<=n; i++) { q.push(i); } int sum=1,i=0,j=0; while(sum<n) { if(j!=k-1) { int tmp=q.front(); q.pop(); q.push(tmp); j++; } else { a[q.front()]=sum; sum++; q.pop(); j=0; } } a[q.front()]=sum; for(int i=1; i<=n; i++) printf("%d ",a[i]); return 0; }
- 1
Information
- ID
- 79
- Time
- 1000ms
- Memory
- 256MiB
- Difficulty
- 5
- Tags
- # Submissions
- 236
- Accepted
- 88
- Uploaded By