用链表实现轻院1276士兵队列训练问题
Posted Been You
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用链表实现轻院1276士兵队列训练问题相关的知识,希望对你有一定的参考价值。
士兵队列训练问题
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 8554 Accepted Submission(s):
3809
Problem Description
某部队进行新兵队列训练,将新兵从一开始按顺序依次编号,并排成一行横队,训练的规则如下:从头开始一至二报数,凡报到二的出列,剩下的向小序号方向靠拢,再从头开始进行一至三报数,凡报到三的出列,剩下的向小序号方向靠拢,继续从头开始进行一至二报数。。。,以后从头开始轮流进行一至二报数、一至三报数直到剩下的人数不超过三人为止。
Input
本题有多个测试数据组,第一行为组数N,接着为N行新兵人数,新兵人数不超过5000。
Output
共有N行,分别对应输入的新兵人数,每行输出剩下的新兵最初的编号,编号之间有一个空格。
Sample Input
2
20
40
Sample Output
1 7 19
1 19 37
该题需要注意n<=3的情况:
当n=1时输出1;
当n=2时输出1 2;
当n=3时输出1 2 3;
1 #include<stdio.h> 2 3 typedef struct node{ 4 int date; 5 struct node *next; 6 }*LinkList; 7 8 LinkList Buile(int n); 9 void delNextNode(LinkList p); 10 int Find(LinkList head, int m, int k); 11 void CountOff(int n); 12 13 int main() 14 { 15 int i, N, n; 16 scanf("%d", &N); 17 while(N--){ 18 scanf("%d", &n); 19 if(n <= 3){ 20 printf("1"); 21 for(i = 2; i <= n; i++) 22 printf(" %d", i); 23 printf("\n"); 24 continue; 25 } 26 CountOff(n); 27 } 28 return 0; 29 } 30 void CountOff(int n) 31 { 32 int k = 2; 33 LinkList head, p; 34 head = Buile(n); 35 while(1){ 36 if(k == 2) 37 k = 1; 38 else 39 k = 2; 40 n = Find(head, n, k); 41 if(n <= 3) 42 break; 43 } 44 45 p = head->next; 46 while(p){ 47 if(k){ 48 printf("%d", p->date); 49 k = 0; 50 } 51 else 52 printf(" %d", p->date); 53 p = p->next; 54 } 55 printf("\n"); 56 } 57 LinkList Buile(int n) 58 { 59 LinkList rear, p, head = new node; 60 rear = head; 61 for(int i = 1; i <= n; i++){ 62 p = new node; 63 p->date = i; 64 rear->next = p; 65 rear = p; 66 } 67 rear->next = NULL; 68 return head; 69 } 70 void DelNextNode(LinkList p) 71 { 72 LinkList pre; 73 pre = p->next; 74 p->next = pre->next; 75 delete pre; 76 } 77 int Find(LinkList head, int m, int k) 78 { 79 int i; 80 LinkList pre = head; 81 while(pre){ 82 i = k; 83 while(i--){ 84 if(pre == NULL) 85 return m; 86 pre = pre->next; 87 } 88 if(!pre || pre->next == NULL) 89 return m; 90 DelNextNode(pre); 91 m--; 92 } 93 return m; 94 }
以上是关于用链表实现轻院1276士兵队列训练问题的主要内容,如果未能解决你的问题,请参考以下文章