私はしばらく試してみましたが、以下のプログラムで N を入力として取り、最後に死ぬ兵士が 13 番目 (N>13) になるように M を生成する方法がわかりません。
 int main()
 {
 int N, M;
 struct node { int player_id; struct node *next; };
 struct node *p, *q;
 int i, count;
 printf("Enter N (number of players): "); scanf("%d", &N);
 printf("Enter M (every M-th payer gets eliminated): "); scanf("%d", &M);
// Create circular linked list containing all the players:
p = q = malloc(sizeof(struct node));
p->player_id = 1;
for (i = 2; i <= N; ++i) {
    p->next = malloc(sizeof(struct node));
    p = p->next;
    p->player_id = i;
}
p->next = q;//Close the circular linkedlist by having the last node point to the 1st   
// Eliminate every M-th player as long as more than one player remains:
for (count = N; count > 1; --count) {
   for (i = 0; i < M - 1; ++i)
 p = p->next;       p->next = p->next->next;
  // Remove the eiminated player from the circular linked list.
     }    printf("Last player left standing is %d\n.", p->player_id);
   return 0;
  }
結果はこれと同じになるはずです(しかし、私はそれを理解していないため、リンクされたリストでそれが必要です):>.