#include<stdio.h> #include<string.h> int main() { int k,n,m,p,q,i,j,s; int a[400],book[400],b[400]; while(~scanf("%d%d%d",&n,&m,&p)&&n+m+p) { memset(a,0,sizeof(a)); memset(book,0,sizeof(book)); memset(b,0,sizeof(b)); for(i=1;i<=n;i++) a[i]=i; k=0,q=m;s=0; while(k<n) { for(i=q;i<=n;i++) { if(book[a[i]]==0) { s++; if(s==p)//够p个数 { b[k++]=a[i];//记录所出的点 s=0; book[a[i]]=1;//所出的点标记 } } } q=1;//除第一次外,都从1开始数 } for(i=0;i<k;i++) { if(i!=k-1) printf("%d,",b[i]); else printf("%d\n",b[i]); } } }转python
时间: 2023-12-09 12:06:27 浏览: 167
#include <stdio.h>
4星 · 用户满意度95%
请注意,这是一段 C 代码,转换成 Python 时需要逐行翻译和调整语法。以下是可能的 Python 代码:
```python
while True:
n, m, p = map(int, input().split())
if n == 0 and m == 0 and p == 0:
break
a = list(range(n + 1))
book = [0] * (n + 1)
b = [0] * n
k, q, s = 0, m, 0
while k < n:
for i in range(q, n + 1):
if book[a[i]] == 0:
s += 1
if s == p:
b[k] = a[i]
k += 1
s = 0
book[a[i]] = 1
q = 1
for i in range(k):
if i != k - 1:
print(b[i], end=",")
else:
print(b[i])
```
请注意,这只是一种可能的实现方法,不一定是最优或最正确的。如果您有更好的实现,请随时分享!
阅读全文