标签:链表实现 ota amp mission memory void rom font next
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 8554 Accepted Submission(s):
3809
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 }
标签:链表实现 ota amp mission memory void rom font next
原文地址:http://www.cnblogs.com/didideblog/p/7073940.html