4
//好扯,感觉自己根本就分析不出其内在的逻辑,真的想不出
#include <stdio.h> int main() { int n, m, i, s = 0; while(scanf("%d",&n)&&n!=0) { s=0; scanf("%d",&m); for (i = 2; i <= n; i++) s = (s + m) % i; printf ("%d\n", s+1); } } /************************************************************** Problem: 1356 User: hndxztf Language: C++ Result: Accepted Time:290 ms Memory:1020 kb ****************************************************************/
//很自然的一种思路,但是时间是个硬伤,无表头建表,循环链表的删除。。。收获还是不少的
#include <cstdio> #include <cstdlib> using namespace std; typedef struct LNode{ struct LNode *next; int data; }*LinkList; LinkList CreateList(LinkList &L,int n) { LinkList q=NULL,p=NULL; L=(LinkList)malloc(sizeof(LinkList*)); L->data=1; L->next=L; p=L; for(int i=2;i<=n;i++) { q=(LinkList)malloc(sizeof(LinkList*)); q->data=i; q->next=L; p->next=q; p=q; } return L; } int FindNum(LinkList L,int m) { LinkList q=NULL,p=L; int count=1; while(p->next!=p) { if(count<m) { p=p->next; count++; } else if(count==m) { q=p->next; p->data=q->data;//通过将后面节点的值赋给前个结点达到删除当前结点的目的 //在循环链表中是可行的 p->next=q->next; //delete q; //q=NULL; count=1; } } return p->data; } int main() { LinkList L=NULL; int n,m; while(scanf("%d",&n)&&n!=0) { scanf("%d",&m); L=CreateList(L,n); printf("%d\n",FindNum(L,m)); } return 0; } /************************************************************** Problem: 1356 User: hndxztf Language: C++ Result: Time Limit Exceed ****************************************************************/